Loading searx/plugins/__init__.py +2 −2 Original line number Diff line number Diff line Loading @@ -20,7 +20,7 @@ from searx import logger logger = logger.getChild('plugins') from searx.plugins import (https_rewrite, self_ip, self_info, search_on_category_select) required_attrs = (('name', str), Loading Loading @@ -71,5 +71,5 @@ class PluginStore(): plugins = PluginStore() plugins.register(https_rewrite) plugins.register(self_ip) plugins.register(self_info) plugins.register(search_on_category_select) searx/plugins/self_ip.py→searx/plugins/self_info.py +11 −2 Original line number Diff line number Diff line Loading @@ -15,11 +15,16 @@ along with searx. If not, see < http://www.gnu.org/licenses/ >. (C) 2015 by Adam Tauber, <asciimoo@gmail.com> ''' from flask.ext.babel import gettext name = "Self IP" description = gettext('Display your source IP address if the query expression is "ip"') import re name = "Self Informations" description = gettext('Displays your IP if the query is "ip" and your user agent if the query contains "user agent".') default_on = True # Self User Agent regex p = re.compile('.*user[ -]agent.*', re.IGNORECASE) # attach callback to the post search hook # request: flask request object # ctx: the whole local context of the pre search hook Loading @@ -32,4 +37,8 @@ def post_search(request, ctx): ip = request.remote_addr ctx['search'].answers.clear() ctx['search'].answers.add(ip) elif p.match(ctx['search'].query): ua = request.user_agent ctx['search'].answers.clear() ctx['search'].answers.add(ua) return True searx/tests/test_plugins.py +18 −1 Original line number Diff line number Diff line Loading @@ -38,10 +38,11 @@ class SelfIPTest(SearxTestCase): def test_PluginStore_init(self): store = plugins.PluginStore() store.register(plugins.self_ip) store.register(plugins.self_info) self.assertTrue(len(store.plugins) == 1) # IP test request = Mock(user_plugins=store.plugins, remote_addr='127.0.0.1') request.headers.getlist.return_value = [] Loading @@ -49,3 +50,19 @@ class SelfIPTest(SearxTestCase): query='ip')} store.call('post_search', request, ctx) self.assertTrue('127.0.0.1' in ctx['search'].answers) # User agent test request = Mock(user_plugins=store.plugins, user_agent='Mock') request.headers.getlist.return_value = [] ctx = {'search': Mock(answers=set(), query='user-agent')} store.call('post_search', request, ctx) self.assertTrue('Mock' in ctx['search'].answers) ctx = {'search': Mock(answers=set(), query='user agent')} store.call('post_search', request, ctx) self.assertTrue('Mock' in ctx['search'].answers) ctx = {'search': Mock(answers=set(), query='What is my User-Agent?')} store.call('post_search', request, ctx) Loading
searx/plugins/__init__.py +2 −2 Original line number Diff line number Diff line Loading @@ -20,7 +20,7 @@ from searx import logger logger = logger.getChild('plugins') from searx.plugins import (https_rewrite, self_ip, self_info, search_on_category_select) required_attrs = (('name', str), Loading Loading @@ -71,5 +71,5 @@ class PluginStore(): plugins = PluginStore() plugins.register(https_rewrite) plugins.register(self_ip) plugins.register(self_info) plugins.register(search_on_category_select)
searx/plugins/self_ip.py→searx/plugins/self_info.py +11 −2 Original line number Diff line number Diff line Loading @@ -15,11 +15,16 @@ along with searx. If not, see < http://www.gnu.org/licenses/ >. (C) 2015 by Adam Tauber, <asciimoo@gmail.com> ''' from flask.ext.babel import gettext name = "Self IP" description = gettext('Display your source IP address if the query expression is "ip"') import re name = "Self Informations" description = gettext('Displays your IP if the query is "ip" and your user agent if the query contains "user agent".') default_on = True # Self User Agent regex p = re.compile('.*user[ -]agent.*', re.IGNORECASE) # attach callback to the post search hook # request: flask request object # ctx: the whole local context of the pre search hook Loading @@ -32,4 +37,8 @@ def post_search(request, ctx): ip = request.remote_addr ctx['search'].answers.clear() ctx['search'].answers.add(ip) elif p.match(ctx['search'].query): ua = request.user_agent ctx['search'].answers.clear() ctx['search'].answers.add(ua) return True
searx/tests/test_plugins.py +18 −1 Original line number Diff line number Diff line Loading @@ -38,10 +38,11 @@ class SelfIPTest(SearxTestCase): def test_PluginStore_init(self): store = plugins.PluginStore() store.register(plugins.self_ip) store.register(plugins.self_info) self.assertTrue(len(store.plugins) == 1) # IP test request = Mock(user_plugins=store.plugins, remote_addr='127.0.0.1') request.headers.getlist.return_value = [] Loading @@ -49,3 +50,19 @@ class SelfIPTest(SearxTestCase): query='ip')} store.call('post_search', request, ctx) self.assertTrue('127.0.0.1' in ctx['search'].answers) # User agent test request = Mock(user_plugins=store.plugins, user_agent='Mock') request.headers.getlist.return_value = [] ctx = {'search': Mock(answers=set(), query='user-agent')} store.call('post_search', request, ctx) self.assertTrue('Mock' in ctx['search'].answers) ctx = {'search': Mock(answers=set(), query='user agent')} store.call('post_search', request, ctx) self.assertTrue('Mock' in ctx['search'].answers) ctx = {'search': Mock(answers=set(), query='What is my User-Agent?')} store.call('post_search', request, ctx)