Browse Source

Merge pull request #371 from framasoft/add-useragent-plugin

Add a self user agent plugin
Adam Tauber 10 years ago
parent
commit
a9d92c3874
3 changed files with 31 additions and 5 deletions
  1. 2 2
      searx/plugins/__init__.py
  2. 11 2
      searx/plugins/self_info.py
  3. 18 1
      searx/tests/test_plugins.py

+ 2 - 2
searx/plugins/__init__.py

@@ -20,7 +20,7 @@ from searx import logger
 logger = logger.getChild('plugins')
 logger = logger.getChild('plugins')
 
 
 from searx.plugins import (https_rewrite,
 from searx.plugins import (https_rewrite,
-                           self_ip,
+                           self_info,
                            search_on_category_select)
                            search_on_category_select)
 
 
 required_attrs = (('name', str),
 required_attrs = (('name', str),
@@ -71,5 +71,5 @@ class PluginStore():
 
 
 plugins = PluginStore()
 plugins = PluginStore()
 plugins.register(https_rewrite)
 plugins.register(https_rewrite)
-plugins.register(self_ip)
+plugins.register(self_info)
 plugins.register(search_on_category_select)
 plugins.register(search_on_category_select)

+ 11 - 2
searx/plugins/self_ip.py → searx/plugins/self_info.py

@@ -15,11 +15,16 @@ along with searx. If not, see < http://www.gnu.org/licenses/ >.
 (C) 2015 by Adam Tauber, <asciimoo@gmail.com>
 (C) 2015 by Adam Tauber, <asciimoo@gmail.com>
 '''
 '''
 from flask.ext.babel import gettext
 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
 default_on = True
 
 
 
 
+# Self User Agent regex
+p = re.compile('.*user[ -]agent.*', re.IGNORECASE)
+
+
 # attach callback to the post search hook
 # attach callback to the post search hook
 #  request: flask request object
 #  request: flask request object
 #  ctx: the whole local context of the pre search hook
 #  ctx: the whole local context of the pre search hook
@@ -32,4 +37,8 @@ def post_search(request, ctx):
             ip = request.remote_addr
             ip = request.remote_addr
         ctx['search'].answers.clear()
         ctx['search'].answers.clear()
         ctx['search'].answers.add(ip)
         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
     return True

+ 18 - 1
searx/tests/test_plugins.py

@@ -38,10 +38,11 @@ class SelfIPTest(SearxTestCase):
 
 
     def test_PluginStore_init(self):
     def test_PluginStore_init(self):
         store = plugins.PluginStore()
         store = plugins.PluginStore()
-        store.register(plugins.self_ip)
+        store.register(plugins.self_info)
 
 
         self.assertTrue(len(store.plugins) == 1)
         self.assertTrue(len(store.plugins) == 1)
 
 
+        # IP test
         request = Mock(user_plugins=store.plugins,
         request = Mock(user_plugins=store.plugins,
                        remote_addr='127.0.0.1')
                        remote_addr='127.0.0.1')
         request.headers.getlist.return_value = []
         request.headers.getlist.return_value = []
@@ -49,3 +50,19 @@ class SelfIPTest(SearxTestCase):
                               query='ip')}
                               query='ip')}
         store.call('post_search', request, ctx)
         store.call('post_search', request, ctx)
         self.assertTrue('127.0.0.1' in ctx['search'].answers)
         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)