|
@@ -123,6 +123,7 @@ from searx.locales import (
|
|
|
|
|
|
|
|
|
from searx.autocomplete import search_autocomplete, backends as autocomplete_backends
|
|
|
+from searx.favicon_resolver import search_favicon, backends as favicon_backends
|
|
|
from searx.redisdb import initialize as redis_initialize
|
|
|
from searx.sxng_locales import sxng_locales
|
|
|
from searx.search import SearchWithPlugins, initialize as search_initialize
|
|
@@ -297,6 +298,24 @@ def morty_proxify(url: str):
|
|
|
return '{0}?{1}'.format(settings['result_proxy']['url'], urlencode(url_params))
|
|
|
|
|
|
|
|
|
+def favicon_proxify(url: str):
|
|
|
+
|
|
|
+
|
|
|
+ resolver = request.preferences.get_value('favicon_resolver')
|
|
|
+
|
|
|
+
|
|
|
+ if not resolver:
|
|
|
+ return ""
|
|
|
+
|
|
|
+
|
|
|
+ if resolver not in favicon_backends:
|
|
|
+ return ""
|
|
|
+
|
|
|
+ h = new_hmac(settings['server']['secret_key'], url.encode())
|
|
|
+
|
|
|
+ return '{0}?{1}'.format(url_for('favicon_proxy'), urlencode(dict(q=url.encode(), h=h)))
|
|
|
+
|
|
|
+
|
|
|
def image_proxify(url: str):
|
|
|
|
|
|
if url.startswith('//'):
|
|
@@ -358,6 +377,7 @@ def get_client_settings():
|
|
|
return {
|
|
|
'autocomplete_provider': req_pref.get_value('autocomplete'),
|
|
|
'autocomplete_min': get_setting('search.autocomplete_min'),
|
|
|
+ 'favicon_resolver': req_pref.get_value('favicon_resolver'),
|
|
|
'http_method': req_pref.get_value('method'),
|
|
|
'infinite_scroll': req_pref.get_value('infinite_scroll'),
|
|
|
'translations': get_translations(),
|
|
@@ -388,6 +408,7 @@ def render(template_name: str, **kwargs):
|
|
|
|
|
|
kwargs['preferences'] = request.preferences
|
|
|
kwargs['autocomplete'] = request.preferences.get_value('autocomplete')
|
|
|
+ kwargs['favicon_resolver'] = request.preferences.get_value('favicon_resolver')
|
|
|
kwargs['infinite_scroll'] = request.preferences.get_value('infinite_scroll')
|
|
|
kwargs['search_on_category_select'] = request.preferences.get_value('search_on_category_select')
|
|
|
kwargs['hotkeys'] = request.preferences.get_value('hotkeys')
|
|
@@ -431,6 +452,7 @@ def render(template_name: str, **kwargs):
|
|
|
|
|
|
kwargs['url_for'] = custom_url_for
|
|
|
kwargs['image_proxify'] = image_proxify
|
|
|
+ kwargs['favicon_proxify'] = favicon_proxify
|
|
|
kwargs['proxify'] = morty_proxify if settings['result_proxy']['url'] is not None else None
|
|
|
kwargs['proxify_results'] = settings['result_proxy']['proxify_results']
|
|
|
kwargs['cache_url'] = settings['ui']['cache_url']
|
|
@@ -873,6 +895,42 @@ def autocompleter():
|
|
|
return Response(suggestions, mimetype=mimetype)
|
|
|
|
|
|
|
|
|
+@app.route('/favicon', methods=['GET'])
|
|
|
+def favicon_proxy():
|
|
|
+ """Return proxied favicon results"""
|
|
|
+ url = request.args.get('q')
|
|
|
+
|
|
|
+
|
|
|
+ if not url:
|
|
|
+ return '', 400
|
|
|
+
|
|
|
+
|
|
|
+ if not is_hmac_of(settings['server']['secret_key'], url.encode(), request.args.get('h', '')):
|
|
|
+ return '', 400
|
|
|
+
|
|
|
+ resolver = request.preferences.get_value('favicon_resolver')
|
|
|
+
|
|
|
+
|
|
|
+ if not resolver or resolver not in favicon_backends:
|
|
|
+ return '', 400
|
|
|
+
|
|
|
+
|
|
|
+ raw_text_query = RawTextQuery(url, [])
|
|
|
+
|
|
|
+ resp = search_favicon(resolver, raw_text_query)
|
|
|
+
|
|
|
+
|
|
|
+ if not resp:
|
|
|
+ theme = request.preferences.get_value("theme")
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ return redirect(url_for('static', filename='themes/' + theme + '/img/empty_favicon.svg'))
|
|
|
+
|
|
|
+
|
|
|
+ return Response(resp, mimetype='image/png')
|
|
|
+
|
|
|
+
|
|
|
@app.route('/preferences', methods=['GET', 'POST'])
|
|
|
def preferences():
|
|
|
"""Render preferences page && save user preferences"""
|
|
@@ -1020,6 +1078,7 @@ def preferences():
|
|
|
],
|
|
|
disabled_engines = disabled_engines,
|
|
|
autocomplete_backends = autocomplete_backends,
|
|
|
+ favicon_backends = favicon_backends,
|
|
|
shortcuts = {y: x for x, y in engine_shortcuts.items()},
|
|
|
themes = themes,
|
|
|
plugins = plugins,
|