From 0549fb40d2ab0b14354e680880b0de3d9d770452 Mon Sep 17 00:00:00 2001 From: jcherqui Date: Sun, 15 Jan 2017 14:24:19 +0100 Subject: Add 1337x.to engine --- searx/engines/1337x.py | 29 +++++++++++++++++++++++++++++ 1 file changed, 29 insertions(+) create mode 100644 searx/engines/1337x.py (limited to 'searx/engines') diff --git a/searx/engines/1337x.py b/searx/engines/1337x.py new file mode 100644 index 000000000..8a5da9cb8 --- /dev/null +++ b/searx/engines/1337x.py @@ -0,0 +1,29 @@ +from urllib import quote +from lxml import html +from searx.engines.xpath import extract_text +from urlparse import urljoin + +url = 'https://1337x.to/' +search_url = url + 'search/{search_term}/{pageno}/' +categories = ['videos', 'music', 'files'] +paging = True + +def request(query, params): + params['url'] = search_url.format(search_term=quote(query), pageno=params['pageno']) + + return params + +def response(resp): + results = [] + + dom = html.fromstring(resp.text) + + for result in dom.xpath('//table[contains(@class, "table-list")]/tbody//tr'): + href = urljoin(url, result.xpath('./td[contains(@class, "name")]/a[2]/@href')[0]) + title = extract_text(result.xpath('./td[contains(@class, "name")]/a[2]')) + + results.append({'url': href, + 'title': title, + 'content': ''}) + + return results -- cgit v1.2.3 From a320328dda1ae2362a4eeb98e4e46f8ce38d33d3 Mon Sep 17 00:00:00 2001 From: jcherqui Date: Sun, 15 Jan 2017 14:50:29 +0100 Subject: Fix test --- searx/engines/1337x.py | 2 ++ 1 file changed, 2 insertions(+) (limited to 'searx/engines') diff --git a/searx/engines/1337x.py b/searx/engines/1337x.py index 8a5da9cb8..8c90a1b3e 100644 --- a/searx/engines/1337x.py +++ b/searx/engines/1337x.py @@ -8,11 +8,13 @@ search_url = url + 'search/{search_term}/{pageno}/' categories = ['videos', 'music', 'files'] paging = True + def request(query, params): params['url'] = search_url.format(search_term=quote(query), pageno=params['pageno']) return params + def response(resp): results = [] -- cgit v1.2.3 From 4776abd1acdc87a218eb6ae894008c6e8df4a2af Mon Sep 17 00:00:00 2001 From: jcherqui Date: Sun, 15 Jan 2017 15:08:43 +0100 Subject: Remove categories --- searx/engines/1337x.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) (limited to 'searx/engines') diff --git a/searx/engines/1337x.py b/searx/engines/1337x.py index 8c90a1b3e..e0cf7e520 100644 --- a/searx/engines/1337x.py +++ b/searx/engines/1337x.py @@ -5,7 +5,7 @@ from urlparse import urljoin url = 'https://1337x.to/' search_url = url + 'search/{search_term}/{pageno}/' -categories = ['videos', 'music', 'files'] +categories = ['videos'] paging = True -- cgit v1.2.3 From 39a97825d9cbcff4b2a29adbae4a745dbfa6c823 Mon Sep 17 00:00:00 2001 From: jcherqui Date: Sun, 15 Jan 2017 15:29:01 +0100 Subject: Add torrent infos --- searx/engines/1337x.py | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) (limited to 'searx/engines') diff --git a/searx/engines/1337x.py b/searx/engines/1337x.py index e0cf7e520..c6bc3cb6d 100644 --- a/searx/engines/1337x.py +++ b/searx/engines/1337x.py @@ -1,6 +1,7 @@ from urllib import quote from lxml import html from searx.engines.xpath import extract_text +from searx.utils import get_torrent_size from urlparse import urljoin url = 'https://1337x.to/' @@ -23,9 +24,17 @@ def response(resp): for result in dom.xpath('//table[contains(@class, "table-list")]/tbody//tr'): href = urljoin(url, result.xpath('./td[contains(@class, "name")]/a[2]/@href')[0]) title = extract_text(result.xpath('./td[contains(@class, "name")]/a[2]')) + seed = extract_text(result.xpath('.//td[contains(@class, "seeds")]')) + leech = extract_text(result.xpath('.//td[contains(@class, "leeches")]')) + filesize_info = extract_text(result.xpath('.//td[contains(@class, "size")]/text()')) + filesize, filesize_multiplier = filesize_info.split() + filesize = get_torrent_size(filesize, filesize_multiplier) results.append({'url': href, 'title': title, - 'content': ''}) + 'seed': seed, + 'leech': leech, + 'filesize': filesize, + 'template': 'torrent.html'}) return results -- cgit v1.2.3