mirror of
https://github.com/searxng/searxng.git
synced 2025-01-11 19:05:24 +00:00
Merge pull request #371 from framasoft/add-useragent-plugin
Add a self user agent plugin
This commit is contained in:
commit
a9d92c3874
3 changed files with 31 additions and 5 deletions
|
@ -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)
|
||||
|
|
|
@ -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
|
|
@ -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)
|
||||
|
|
Loading…
Reference in a new issue