Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit a9d92c38 authored by Adam Tauber's avatar Adam Tauber
Browse files

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

Add a self user agent plugin
parents c9b8c7f8 0fe362ba
Loading
Loading
Loading
Loading
+2 −2
Original line number Diff line number Diff line
@@ -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),
@@ -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)
+11 −2
Original line number Diff line number Diff line
@@ -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
@@ -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
+18 −1
Original line number Diff line number Diff line
@@ -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 = []
@@ -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)