diff options
| author | Alexandre Flament <alex@al-f.net> | 2022-05-07 18:05:31 +0200 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2022-05-07 18:05:31 +0200 |
| commit | 30756d5cfc517f63a0778a54799ab6431e062e56 (patch) | |
| tree | 91c9db421b6215bbfd188aae97b846dd71e9cfe7 /searx/webapp.py | |
| parent | 9177172ea21852e16f00896806bf1b573fd9bb8f (diff) | |
| parent | 8175290867f6425226d87377512d2ce20fd72a26 (diff) | |
Merge pull request #1091 from return42/client-settings
[mod] client_settings: pass settings from server to JS client
Diffstat (limited to 'searx/webapp.py')
| -rwxr-xr-x | searx/webapp.py | 35 |
1 files changed, 31 insertions, 4 deletions
diff --git a/searx/webapp.py b/searx/webapp.py index 3d3f736a5..178500df6 100755 --- a/searx/webapp.py +++ b/searx/webapp.py @@ -10,6 +10,7 @@ import hmac import json import os import sys +import base64 from datetime import datetime, timedelta from timeit import default_timer @@ -444,7 +445,37 @@ def get_pretty_url(parsed_url: urllib.parse.ParseResult): return [parsed_url.scheme + "://" + parsed_url.netloc, path] +def get_client_settings(): + req_pref = request.preferences + return { + 'autocomplete_provider': req_pref.get_value('autocomplete'), + 'autocomplete_min' : get_setting('search.autocomplete_min'), + 'http_method': req_pref.get_value('method'), + 'infinite_scroll': req_pref.get_value('infinite_scroll'), + 'translations': get_translations(), + 'search_on_category_select': req_pref.plugins.choices['searx.plugins.search_on_category_select'], + 'hotkeys': req_pref.plugins.choices['searx.plugins.vim_hotkeys'], + 'theme_static_path': custom_url_for('static', filename='themes/simple'), + } + + def render(template_name: str, override_theme: str = None, **kwargs): + + kwargs['client_settings'] = str( + base64.b64encode( + bytes( + json.dumps(get_client_settings()), + encoding='utf-8', + ) + ), encoding='utf-8', + ) + + # obsolete, only needed by oscar + kwargs['autocomplete'] = request.preferences.get_value('autocomplete') + kwargs['method'] = request.preferences.get_value('method') + kwargs['infinite_scroll'] = request.preferences.get_value('infinite_scroll') + kwargs['translations'] = json.dumps(get_translations(), separators=(',', ':')) + # values from the HTTP requests kwargs['endpoint'] = 'results' if 'q' in kwargs else request.endpoint kwargs['cookies'] = request.cookies @@ -452,9 +483,6 @@ def render(template_name: str, override_theme: str = None, **kwargs): # values from the preferences kwargs['preferences'] = request.preferences - kwargs['method'] = request.preferences.get_value('method') - kwargs['autocomplete'] = request.preferences.get_value('autocomplete') - kwargs['infinite_scroll'] = request.preferences.get_value('infinite_scroll') kwargs['results_on_new_tab'] = request.preferences.get_value('results_on_new_tab') kwargs['advanced_search'] = request.preferences.get_value('advanced_search') kwargs['query_in_title'] = request.preferences.get_value('query_in_title') @@ -466,7 +494,6 @@ def render(template_name: str, override_theme: str = None, **kwargs): # i18n kwargs['language_codes'] = [l for l in languages if l[0] in settings['search']['languages']] - kwargs['translations'] = json.dumps(get_translations(), separators=(',', ':')) locale = request.preferences.get_value('locale') kwargs['locale_rfc5646'] = _get_locale_rfc5646(locale) |