| 
							
							#  Seedpeer (Videos, Music, Files)
 | 
						
						
						
						
							 | 
							
							#
 | 
						
						
						
						
							 | 
							
							# @website     http://seedpeer.eu
 | 
						
						
						
						
							 | 
							
							# @provide-api no (nothing found)
 | 
						
						
						
						
							 | 
							
							#
 | 
						
						
						
						
							 | 
							
							# @using-api   no
 | 
						
						
						
						
							 | 
							
							# @results     HTML (using search portal)
 | 
						
						
						
						
							 | 
							
							# @stable      yes (HTML can change)
 | 
						
						
						
						
							 | 
							
							# @parse       url, title, content, seed, leech, magnetlink
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							from lxml import html
 | 
						
						
						
						
							 | 
							
							from operator import itemgetter
 | 
						
						
						
						
							 | 
							
							from searx.url_utils import quote, urljoin
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							url = 'http://www.seedpeer.eu/'
 | 
						
						
						
						
							 | 
							
							search_url = url + 'search/{search_term}/7/{page_no}.html'
 | 
						
						
						
						
							 | 
							
							# specific xpath variables
 | 
						
						
						
						
							 | 
							
							torrent_xpath = '//*[@id="body"]/center/center/table[2]/tr/td/a'
 | 
						
						
						
						
							 | 
							
							alternative_torrent_xpath = '//*[@id="body"]/center/center/table[1]/tr/td/a'
 | 
						
						
						
						
							 | 
							
							title_xpath = '//*[@id="body"]/center/center/table[2]/tr/td/a/text()'
 | 
						
						
						
						
							 | 
							
							alternative_title_xpath = '//*[@id="body"]/center/center/table/tr/td/a'
 | 
						
						
						
						
							 | 
							
							seeds_xpath = '//*[@id="body"]/center/center/table[2]/tr/td[4]/font/text()'
 | 
						
						
						
						
							 | 
							
							alternative_seeds_xpath = '//*[@id="body"]/center/center/table/tr/td[4]/font/text()'
 | 
						
						
						
						
							 | 
							
							peers_xpath = '//*[@id="body"]/center/center/table[2]/tr/td[5]/font/text()'
 | 
						
						
						
						
							 | 
							
							alternative_peers_xpath = '//*[@id="body"]/center/center/table/tr/td[5]/font/text()'
 | 
						
						
						
						
							 | 
							
							age_xpath = '//*[@id="body"]/center/center/table[2]/tr/td[2]/text()'
 | 
						
						
						
						
							 | 
							
							alternative_age_xpath = '//*[@id="body"]/center/center/table/tr/td[2]/text()'
 | 
						
						
						
						
							 | 
							
							size_xpath = '//*[@id="body"]/center/center/table[2]/tr/td[3]/text()'
 | 
						
						
						
						
							 | 
							
							alternative_size_xpath = '//*[@id="body"]/center/center/table/tr/td[3]/text()'
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							# do search-request
 | 
						
						
						
						
							 | 
							
							def request(query, params):
 | 
						
						
						
						
							 | 
							
							    params['url'] = search_url.format(search_term=quote(query),
 | 
						
						
						
						
							 | 
							
							                                      page_no=params['pageno'] - 1)
 | 
						
						
						
						
							 | 
							
							    return params
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							# get response from search-request
 | 
						
						
						
						
							 | 
							
							def response(resp):
 | 
						
						
						
						
							 | 
							
							    results = []
 | 
						
						
						
						
							 | 
							
							    dom = html.fromstring(resp.text)
 | 
						
						
						
						
							 | 
							
							    torrent_links = dom.xpath(torrent_xpath)
 | 
						
						
						
						
							 | 
							
							    if len(torrent_links) > 0:
 | 
						
						
						
						
							 | 
							
							        seeds = dom.xpath(seeds_xpath)
 | 
						
						
						
						
							 | 
							
							        peers = dom.xpath(peers_xpath)
 | 
						
						
						
						
							 | 
							
							        titles = dom.xpath(title_xpath)
 | 
						
						
						
						
							 | 
							
							        sizes = dom.xpath(size_xpath)
 | 
						
						
						
						
							 | 
							
							        ages = dom.xpath(age_xpath)
 | 
						
						
						
						
							 | 
							
							    else:  # under ~5 results uses a different xpath
 | 
						
						
						
						
							 | 
							
							        torrent_links = dom.xpath(alternative_torrent_xpath)
 | 
						
						
						
						
							 | 
							
							        seeds = dom.xpath(alternative_seeds_xpath)
 | 
						
						
						
						
							 | 
							
							        peers = dom.xpath(alternative_peers_xpath)
 | 
						
						
						
						
							 | 
							
							        titles = dom.xpath(alternative_title_xpath)
 | 
						
						
						
						
							 | 
							
							        sizes = dom.xpath(alternative_size_xpath)
 | 
						
						
						
						
							 | 
							
							        ages = dom.xpath(alternative_age_xpath)
 | 
						
						
						
						
							 | 
							
							    # return empty array if nothing is found
 | 
						
						
						
						
							 | 
							
							    if not torrent_links:
 | 
						
						
						
						
							 | 
							
							        return []
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							    # parse results
 | 
						
						
						
						
							 | 
							
							    for index, result in enumerate(torrent_links):
 | 
						
						
						
						
							 | 
							
							        link = result.attrib.get('href')
 | 
						
						
						
						
							 | 
							
							        href = urljoin(url, link)
 | 
						
						
						
						
							 | 
							
							        results.append({'url': href,
 | 
						
						
						
						
							 | 
							
							                        'title': titles[index].text_content(),
 | 
						
						
						
						
							 | 
							
							                        'content': '{}, {}'.format(sizes[index], ages[index]),
 | 
						
						
						
						
							 | 
							
							                        'seed': seeds[index],
 | 
						
						
						
						
							 | 
							
							                        'leech': peers[index],
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							                        'template': 'torrent.html'})
 | 
						
						
						
						
							 | 
							
							
 | 
						
						
						
						
							 | 
							
							    # return results sorted by seeder
 | 
						
						
						
						
							 | 
							
							    return sorted(results, key=itemgetter('seed'), reverse=True)
 |