Sunil Mohan Adapa 900c0d30b9
*: Drop module level app property
module.app property usage is greatly reduced because setup() and force_upgrade()
method are now part of App class instead of at the module level. Remove the
remaining minor cases of usage and drop the property altogether.

Signed-off-by: Sunil Mohan Adapa <sunil@medhas.org>
Reviewed-by: James Valleroy <jvalleroy@mailbox.org>
2022-08-15 10:36:29 -04:00

57 lines
1.9 KiB
Python

# SPDX-License-Identifier: AGPL-3.0-or-later
"""
Django views for Searx.
"""
from django.contrib import messages
from django.utils.translation import gettext as _
from plinth import actions
from plinth import app as app_module
from plinth import views
from plinth.errors import ActionError
from plinth.modules import searx
from .forms import SearxForm
class SearxAppView(views.AppView):
"""Serve configuration page."""
app_id = 'searx'
form_class = SearxForm
def get_initial(self):
"""Return the status of the service to fill in the form."""
initial = super().get_initial()
initial['safe_search'] = searx.get_safe_search_setting()
initial['public_access'] = searx.is_public_access_enabled() and \
app_module.App.get('searx').is_enabled()
return initial
def form_valid(self, form):
"""Apply the changes submitted in the form."""
old_data = form.initial
form_data = form.cleaned_data
if str(old_data['safe_search']) != form_data['safe_search']:
try:
actions.superuser_run(
'searx', ['set-safe-search', form_data['safe_search']])
messages.success(self.request, _('Configuration updated.'))
except ActionError:
messages.error(self.request,
_('An error occurred during configuration.'))
if old_data['public_access'] != form_data['public_access']:
try:
if form_data['public_access']:
searx.enable_public_access()
else:
searx.disable_public_access()
messages.success(self.request, _('Configuration updated.'))
except ActionError:
messages.error(self.request,
_('An error occurred during configuration.'))
return super().form_valid(form)