summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAlexandre Flament <alex@al-f.net>2021-08-16 17:10:28 +0200
committerGitHub <noreply@github.com>2021-08-16 17:10:28 +0200
commita925254c3d19c6a3badf43469816fc1b497e2990 (patch)
treed4016579defb7a8c4bd4b75dfd47b95709b2bdce
parent0b0071af00d4e7b2ebfa298a1e80dbec02205c13 (diff)
parent3f3b5d6181e0bc07a5177651d3221a479b214523 (diff)
downloadsearxng-a925254c3d19c6a3badf43469816fc1b497e2990.tar.gz
searxng-a925254c3d19c6a3badf43469816fc1b497e2990.zip
Merge pull request #258 from dalf/plugin_minor_change
[mod] plugins: minor change
-rw-r--r--searx/plugins/__init__.py13
1 files changed, 11 insertions, 2 deletions
diff --git a/searx/plugins/__init__.py b/searx/plugins/__init__.py
index 45b210662..3a35f7025 100644
--- a/searx/plugins/__init__.py
+++ b/searx/plugins/__init__.py
@@ -40,7 +40,8 @@ required_attrs = (('name', str),
('default_on', bool))
optional_attrs = (('js_dependencies', tuple),
- ('css_dependencies', tuple))
+ ('css_dependencies', tuple),
+ ('preference_section', str))
class Plugin():
@@ -63,9 +64,17 @@ class PluginStore():
plugins = load_external_plugins(plugins)
for plugin in plugins:
for plugin_attr, plugin_attr_type in required_attrs:
- if not hasattr(plugin, plugin_attr) or not isinstance(getattr(plugin, plugin_attr), plugin_attr_type):
+ if not hasattr(plugin, plugin_attr):
logger.critical('missing attribute "{0}", cannot load plugin: {1}'.format(plugin_attr, plugin))
exit(3)
+ attr = getattr(plugin, plugin_attr)
+ if not isinstance(attr, plugin_attr_type):
+ type_attr = str(type(attr))
+ logger.critical(
+ 'attribute "{0}" is of type {2}, must be of type {3}, cannot load plugin: {1}'
+ .format(plugin_attr, plugin, type_attr, plugin_attr_type)
+ )
+ exit(3)
for plugin_attr, plugin_attr_type in optional_attrs:
if not hasattr(plugin, plugin_attr) or not isinstance(getattr(plugin, plugin_attr), plugin_attr_type):
setattr(plugin, plugin_attr, plugin_attr_type())