12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182 |
- '''
- searx is free software: you can redistribute it and/or modify
- it under the terms of the GNU Affero General Public License as published by
- the Free Software Foundation, either version 3 of the License, or
- (at your option) any later version.
- searx is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU Affero General Public License for more details.
- You should have received a copy of the GNU Affero General Public License
- along with searx. If not, see < http://www.gnu.org/licenses/ >.
- (C) 2013- by Adam Tauber, <asciimoo@gmail.com>
- '''
- from lxml import etree
- from requests import get
- from json import loads
- from urllib import urlencode
- def dbpedia(query):
- # dbpedia autocompleter
- autocomplete_url = 'http://lookup.dbpedia.org/api/search.asmx/KeywordSearch?' # noqa
- response = get(autocomplete_url
- + urlencode(dict(QueryString=query)))
- results = []
- if response.ok:
- dom = etree.fromstring(response.content)
- results = dom.xpath('//a:Result/a:Label//text()',
- namespaces={'a': 'http://lookup.dbpedia.org/'})
- return results
- def duckduckgo(query):
- # duckduckgo autocompleter
- url = 'https://ac.duckduckgo.com/ac/?{0}&type=list'
- resp = loads(get(url.format(urlencode(dict(q=query)))).text)
- if len(resp) > 1:
- return resp[1]
- return []
- def google(query):
- # google autocompleter
- autocomplete_url = 'http://suggestqueries.google.com/complete/search?client=toolbar&' # noqa
- response = get(autocomplete_url
- + urlencode(dict(q=query)))
- results = []
- if response.ok:
- dom = etree.fromstring(response.text)
- results = dom.xpath('//suggestion/@data')
- return results
- def wikipedia(query):
- # wikipedia autocompleter
- url = 'https://en.wikipedia.org/w/api.php?action=opensearch&{0}&limit=10&namespace=0&format=json' # noqa
- resp = loads(get(url.format(urlencode(dict(search=query)))).text)
- if len(resp) > 1:
- return resp[1]
- return []
- backends = {'dbpedia': dbpedia,
- 'duckduckgo': duckduckgo,
- 'google': google,
- 'wikipedia': wikipedia
- }
|