summaryrefslogtreecommitdiff
path: root/searx/engines/subtitleseeker.py
blob: c72f81899f2b67dbfe052551db7cd9f3168de290 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
## Subtitleseeker (Video)
#
# @website     http://www.subtitleseeker.com
# @provide-api no
#
# @using-api   no
# @results     HTML
# @stable      no (HTML can change)
# @parse       url, title, content

from cgi import escape
from urllib import quote_plus
from lxml import html

# engine dependent config
categories = ['videos']
paging = True

language = ""

# search-url
url = 'http://www.subtitleseeker.com/'
search_url = url+'search/TITLES/{query}&p={pageno}'

# specific xpath variables
results_xpath = '//div[@class="boxRows"]'


# do search-request
def request(query, params):
    params['url'] = search_url.format(query=quote_plus(query),
                                      pageno=params['pageno'])
    return params


# get response from search-request
def response(resp):
    results = []

    dom = html.fromstring(resp.text)

    # parse results
    for result in dom.xpath(results_xpath):
        link = result.xpath(".//a")[0]
        href = link.attrib.get('href')
        
        if language is not "":
            href = href + language + "/"

        title = escape(link.xpath(".//text()")[0])

        content = result.xpath('.//div[contains(@class,"red")]//text()')[0]
        content = content + " - "
        content = content + html.tostring(result.xpath('.//div[contains(@class,"grey-web")]')[0], method='text')

        if result.xpath(".//span") != []:
            content = content + " - (" + result.xpath(".//span//text()")[0].strip() + ")"

        # append result
        results.append({'url': href,
                        'title': title,
                        'content': escape(content)})

    # return results
    return results