From 7a21e9f6117fc6a72830b1492e421e936e8c2a66 Mon Sep 17 00:00:00 2001 From: "Ed (ODSC)" Date: Mon, 9 Dec 2024 10:50:10 +0000 Subject: [PATCH] views.py: Specific JSON parsing error --- CHANGELOG.md | 1 + libcoveweb2/views.py | 38 +++++++++++++++++++++++++++----------- 2 files changed, 28 insertions(+), 11 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index a68edf0..00d5f53 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -10,6 +10,7 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0. ## Changed - In `TaskWithState.process_get_state()` any changes to `process_data` are now ignored. https://github.com/OpenDataServices/lib-cove-web-2/issues/14 +- Provide a specific error when JSON parsing fails, rather than generic "There was an error." ## [0.3.0] - 2023-09-14 diff --git a/libcoveweb2/views.py b/libcoveweb2/views.py index 9cdf7c4..72b78a2 100644 --- a/libcoveweb2/views.py +++ b/libcoveweb2/views.py @@ -149,17 +149,33 @@ def view_does_not_exist(self, request): def view_data_has_error(self, request, supplied_data): """Called if the supplied data has any error set.""" - return render( - request, - self.error_template, - { - "sub_title": _("Sorry, there was an error."), - "link": "index", - "link_text": _("Go to Home page"), - "msg": _("There was an error."), - }, - status=500, - ) + if supplied_data.error.startswith("JSON: Data parsing error"): + return render( + request, + self.error_template, + { + "sub_title": _("Data parsing error."), + "link": "index", + "link_text": _("Go to Home page"), + "msg": _( + "The data is not valid JSON. " + + "Use a JSON validator tool to correct your data." + ), + }, + status=500, + ) + else: + return render( + request, + self.error_template, + { + "sub_title": _("Sorry, there was an error."), + "link": "index", + "link_text": _("Go to Home page"), + "msg": _("There was an error."), + }, + status=500, + ) def view_has_expired(self, request, supplied_data): """Called if the data has expired and has now been deleted.