summaryrefslogtreecommitdiff
path: root/searx/engines/fdroid.py
diff options
context:
space:
mode:
authorAlexandre Flament <alex@al-f.net>2019-08-05 15:57:33 +0200
committerGitHub <noreply@github.com>2019-08-05 15:57:33 +0200
commit12f891da8496fad1f1fa24eeb52b1b19f03f8678 (patch)
treefe054e6a10efe9496419fbcd7b3d8a918be52a17 /searx/engines/fdroid.py
parent91a59ff3502803611953820e2923348440f807d0 (diff)
parent1cee2c1796f50b2646c8dee0fcc5e9df754c9246 (diff)
Merge pull request #1669 from dalf/engine-fixes
Engine fixes
Diffstat (limited to 'searx/engines/fdroid.py')
-rw-r--r--searx/engines/fdroid.py29
1 files changed, 14 insertions, 15 deletions
diff --git a/searx/engines/fdroid.py b/searx/engines/fdroid.py
index a6b01a8ee..4066dc716 100644
--- a/searx/engines/fdroid.py
+++ b/searx/engines/fdroid.py
@@ -18,13 +18,13 @@ categories = ['files']
paging = True
# search-url
-base_url = 'https://f-droid.org/'
-search_url = base_url + 'repository/browse/?{query}'
+base_url = 'https://search.f-droid.org/'
+search_url = base_url + '?{query}'
# do search-request
def request(query, params):
- query = urlencode({'fdfilter': query, 'fdpage': params['pageno']})
+ query = urlencode({'q': query, 'page': params['pageno'], 'lang': ''})
params['url'] = search_url.format(query=query)
return params
@@ -35,17 +35,16 @@ def response(resp):
dom = html.fromstring(resp.text)
- for app in dom.xpath('//div[@id="appheader"]'):
- url = app.xpath('./ancestor::a/@href')[0]
- title = app.xpath('./p/span/text()')[0]
- img_src = app.xpath('.//img/@src')[0]
-
- content = extract_text(app.xpath('./p')[0])
- content = content.replace(title, '', 1).strip()
-
- results.append({'url': url,
- 'title': title,
- 'content': content,
- 'img_src': img_src})
+ for app in dom.xpath('//a[@class="package-header"]'):
+ app_url = app.xpath('./@href')[0]
+ app_title = extract_text(app.xpath('./div/h4[@class="package-name"]/text()'))
+ app_content = extract_text(app.xpath('./div/div/span[@class="package-summary"]')).strip() \
+ + ' - ' + extract_text(app.xpath('./div/div/span[@class="package-license"]')).strip()
+ app_img_src = app.xpath('./img[@class="package-icon"]/@src')[0]
+
+ results.append({'url': app_url,
+ 'title': app_title,
+ 'content': app_content,
+ 'img_src': app_img_src})
return results