# SPDX-License-Identifier: AGPL-3.0-or-later """ FreedomBox app for running diagnostics. """ import logging from django.http import Http404 from django.template.response import TemplateResponse from django.utils.translation import gettext_lazy as _ from django.views.decorators.http import require_POST from plinth.app import App from plinth.modules import diagnostics logger = logging.getLogger(__name__) def index(request): """Serve the index page""" if request.method == 'POST' and not diagnostics.running_task: diagnostics.start_task() is_running = diagnostics.running_task is not None with diagnostics.results_lock: results = diagnostics.current_results return TemplateResponse( request, 'diagnostics.html', { 'app_info': diagnostics.app.info, 'is_running': is_running, 'results': results, 'refresh_page_sec': 3 if is_running else None }) @require_POST def diagnose_app(request, app_id): """Return diagnostics for a particular app.""" try: app = App.get(app_id) except KeyError: raise Http404('App does not exist') app_name = app.info.name or app_id diagnosis = None diagnosis_exception = None try: diagnosis = app.diagnose() except Exception as exception: logger.exception('Error running %s diagnostics - %s', app_id, exception) diagnosis_exception = str(exception) return TemplateResponse( request, 'diagnostics_app.html', { 'title': _('Diagnostic Test'), 'app_name': app_name, 'results': diagnosis, 'exception': diagnosis_exception, })