mirror of
https://github.com/searxng/searxng.git
synced 2024-11-26 04:41:00 +00:00
efd69c4ca9
This change does the following things: - the `ip` keyword is now case-insensitive - if the query includes `my ip` it will now also match In order to avoid too many false matches, the `ip` keyword alone matches only if it's the _only_ word, but the inclusion of `my` loosens that to be inclusive of users type a phrase (eg, "what is my ip", "tell me my ip", "my IP address", etc). Better answer context Previously this plugin simply dumped your IP or user-agent string as an answer. This tiny change just adds some text to contextualize those answers (eg, "Your IP is: 1.2.3.4" instead of just "1.2.3.4").
32 lines
1.1 KiB
Python
32 lines
1.1 KiB
Python
# SPDX-License-Identifier: AGPL-3.0-or-later
|
|
# pylint: disable=missing-module-docstring,invalid-name
|
|
|
|
import re
|
|
from flask_babel import gettext
|
|
|
|
from searx.botdetection._helpers import get_real_ip
|
|
|
|
name = gettext('Self Information')
|
|
description = gettext('Displays your IP if the query is "ip" and your user agent if the query contains "user agent".')
|
|
default_on = True
|
|
preference_section = 'query'
|
|
query_keywords = ['user-agent']
|
|
query_examples = ''
|
|
|
|
# "ip" or "my ip" regex
|
|
ip_regex = re.compile('^ip$|my ip', re.IGNORECASE)
|
|
|
|
# Self User Agent regex
|
|
ua_regex = re.compile('.*user[ -]agent.*', re.IGNORECASE)
|
|
|
|
|
|
def post_search(request, search):
|
|
if search.search_query.pageno > 1:
|
|
return True
|
|
if ip_regex.search(search.search_query.query):
|
|
ip = get_real_ip(request)
|
|
search.result_container.answers['ip'] = {'answer': gettext('Your IP is: ') + ip}
|
|
elif ua_regex.match(search.search_query.query):
|
|
ua = request.user_agent
|
|
search.result_container.answers['user-agent'] = {'answer': gettext('Your user-agent is: ') + ua}
|
|
return True
|