From fd09e109876cb2d08b30658371f67ea0f6277e04 Mon Sep 17 00:00:00 2001 From: Jason Date: Sun, 10 Dec 2023 16:05:37 -0500 Subject: [PATCH] handle the edge case that there's only one qr code... like tf 0 - 1 = -1 index of -1 and index of 0 is the same.... + fmt --- core/views/qr.py | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/core/views/qr.py b/core/views/qr.py index 7c8ef78..78cbb9b 100644 --- a/core/views/qr.py +++ b/core/views/qr.py @@ -1,3 +1,5 @@ +from __future__ import annotations + from functools import wraps from queue import LifoQueue @@ -124,17 +126,17 @@ def qr(request, key): context = dict(first=False) context["qr_code"]: QrCode codes = QrCode.code_pks(request.user.current_team) - qr_code = QrCode.objects.filter(key=key).first() + qr_code: QrCode | None = QrCode.objects.filter(key=key).first() print(f"{codes=}") print(f"{request.user.current_team.current_qr_i=}") - # print(f"{qr_code.id=}") if qr_code is None: - # User just tried brute-forcing + # User just tried brute-forcing keys... lol context["offpath"] = True return render(request, "core/qr.html", context=context) elif ( qr_code.id == codes[request.user.current_team.current_qr_i - 1] - ): # the user reloaded the page after advancing + and len(codes) > 1 + ): # the user reloaded the page after advancing...or there is only one qr code in the hunt return redirect(reverse("qr_current")) elif ( qr_code.id != codes[request.user.current_team.current_qr_i]