diff --git a/src/backend/apps/shared/views.py b/src/backend/apps/shared/views.py index a5d73b9ef..9164305ea 100644 --- a/src/backend/apps/shared/views.py +++ b/src/backend/apps/shared/views.py @@ -41,19 +41,26 @@ class FeedbackSerializer(Serializer): class FeedbackView(APIView): def post(self, request): serializer = FeedbackSerializer(data=request.data, context={"request": request}) - serializer.is_valid() - # score = serializer.fields['recToken'].score - # serializer.data['subject'] - - send_mail( - "DriveBC Feedback message", - serializer.data['message'], - serializer.data['email'], - [env("DRIVEBC_FEEDBACK_EMAIL_DEFAULT")], - fail_silently=False, - ) - return Response(data={}, status=status.HTTP_200_OK) + try: + serializer.is_valid() + + # Currently unused but potentially important data + # score = serializer.fields['recToken'].score + # subject = serializer.data['subject'] + + send_mail( + "DriveBC Feedback message", + serializer.data['message'], + serializer.data['email'], + [env("DRIVEBC_FEEDBACK_EMAIL_DEFAULT")], + fail_silently=False, + ) + + return Response(data={}, status=status.HTTP_200_OK) + + except Exception: + return Response(data={}, status=status.HTTP_400_BAD_REQUEST) class CachedListModelMixin: diff --git a/src/frontend/src/pages/FeedbackPage.js b/src/frontend/src/pages/FeedbackPage.js index 42450efc6..7cd2f4a9c 100644 --- a/src/frontend/src/pages/FeedbackPage.js +++ b/src/frontend/src/pages/FeedbackPage.js @@ -21,10 +21,14 @@ export default function FeedbackPage() { const [ email, setEmail ] = useState(); const [ subject, setSubject ] = useState(0); const [ message, setMessage ] = useState(); + const [ error, setError ] = useState(false); const [ success, setSuccess ] = useState(false); // Recaptcha const [ recToken, setRecToken ] = useState(); + const refreshRecToken = async () => { + setRecToken(await executeRecaptcha('feedbackForm')); + } const { executeRecaptcha } = useGoogleReCaptcha(); const handleReCaptchaVerify = useCallback(async () => { @@ -32,8 +36,7 @@ export default function FeedbackPage() { return; } - setRecToken(await executeRecaptcha('feedbackForm')); - + refreshRecToken(); }, [executeRecaptcha]); useEffect(() => { @@ -62,6 +65,10 @@ export default function FeedbackPage() { }) .catch((error) => { console.log(error); + setError(true); + + // Refresh captcha token on error + refreshRecToken(); }); }; @@ -96,6 +103,10 @@ export default function FeedbackPage() { + + {error && + Error on submission. Please try again. + } }