summaryrefslogtreecommitdiff
path: root/searx/engines
diff options
context:
space:
mode:
authorAdam Tauber <asciimoo@gmail.com>2019-10-14 14:18:41 +0200
committerAdam Tauber <asciimoo@gmail.com>2019-10-14 14:18:41 +0200
commit77a70fe54165547b0f8f5e1a2cf7f2b9b706805d (patch)
tree6e8b0ddcf56c209beca49a2967325b9553753a6c /searx/engines
parent3d0c22c58d011579277868838bbb2255eaf174af (diff)
downloadsearxng-77a70fe54165547b0f8f5e1a2cf7f2b9b706805d.tar.gz
searxng-77a70fe54165547b0f8f5e1a2cf7f2b9b706805d.zip
[fix] update startpage engine - closes #1601
Diffstat (limited to 'searx/engines')
-rw-r--r--searx/engines/startpage.py27
1 files changed, 19 insertions, 8 deletions
diff --git a/searx/engines/startpage.py b/searx/engines/startpage.py
index 6638f3d83..868b964fb 100644
--- a/searx/engines/startpage.py
+++ b/searx/engines/startpage.py
@@ -15,6 +15,7 @@ from dateutil import parser
from datetime import datetime, timedelta
import re
from searx.engines.xpath import extract_text
+from searx.languages import language_codes
# engine dependent config
categories = ['general']
@@ -22,7 +23,7 @@ categories = ['general']
# (probably the parameter qid), require
# storing of qid's between mulitble search-calls
-# paging = False
+paging = True
language_support = True
# search-url
@@ -32,23 +33,33 @@ search_url = base_url + 'do/search'
# specific xpath variables
# ads xpath //div[@id="results"]/div[@id="sponsored"]//div[@class="result"]
# not ads: div[@class="result"] are the direct childs of div[@id="results"]
-results_xpath = '//li[contains(@class, "search-result") and contains(@class, "search-item")]'
-link_xpath = './/h3/a'
-content_xpath = './p[@class="search-item__body"]'
+results_xpath = '//div[@class="w-gl__result"]'
+link_xpath = './/a[@class="w-gl__result-title"]'
+content_xpath = './/p[@class="w-gl__description"]'
# do search-request
def request(query, params):
- offset = (params['pageno'] - 1) * 10
params['url'] = search_url
params['method'] = 'POST'
- params['data'] = {'query': query,
- 'startat': offset}
+ params['data'] = {
+ 'query': query,
+ 'page': params['pageno'],
+ 'cat': 'web',
+ 'cmd': 'process_search',
+ 'engine0': 'v1all',
+ }
+
# set language if specified
if params['language'] != 'all':
- params['data']['with_language'] = ('lang_' + params['language'].split('-')[0])
+ language = 'english'
+ for lc, _, _, lang in language_codes:
+ if lc == params['language']:
+ language = lang
+ params['data']['language'] = language
+ params['data']['lui'] = language
return params