| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081 | # SPDX-License-Identifier: AGPL-3.0-or-later""" Rumble (Videos)"""from urllib.parse import urlencodefrom lxml import htmlfrom datetime import datetime# aboutfrom searx.utils import extract_textabout = {    "website": 'https://rumble.com/',    "wikidata_id": 'Q104765127',    "official_api_documentation": 'https://help.rumble.com/',    "use_official_api": False,    "require_api_key": False,    "results": 'HTML',}# engine dependent configcategories = ['videos']paging = True# search-urlbase_url = 'https://rumble.com'# https://rumble.com/search/video?q=searx&page=3search_url = base_url + '/search/video?{query}&page={pageno}'url_xpath = './/a[@class="video-item--a"]/@href'thumbnail_xpath = './/img[@class="video-item--img"]/@src'title_xpath = './/h3[@class="video-item--title"]'published_date = './/time[@class="video-item--meta video-item--time"]/@datetime'earned_xpath = './/span[@class="video-item--meta video-item--earned"]/@data-value'views_xpath = './/span[@class="video-item--meta video-item--views"]/@data-value'rumbles_xpath = './/span[@class="video-item--meta video-item--rumbles"]/@data-value'author_xpath = './/div[@class="ellipsis-1"]'length_xpath = './/span[@class="video-item--duration"]/@data-value'def request(query, params):    params['url'] = search_url.format(pageno=params['pageno'], query=urlencode({'q': query}))    return paramsdef response(resp):    results = []    dom = html.fromstring(resp.text)    results_dom = dom.xpath('//li[contains(@class, "video-listing-entry")]')    if not results_dom:        return []    for result_dom in results_dom:        url = base_url + extract_text(result_dom.xpath(url_xpath))        thumbnail = extract_text(result_dom.xpath(thumbnail_xpath))        title = extract_text(result_dom.xpath(title_xpath))        p_date = extract_text(result_dom.xpath(published_date))        # fix offset date for line 644 webapp.py check        fixed_date = datetime.strptime(p_date, '%Y-%m-%dT%H:%M:%S%z')        earned = extract_text(result_dom.xpath(earned_xpath))        views = extract_text(result_dom.xpath(views_xpath))        rumbles = extract_text(result_dom.xpath(rumbles_xpath))        author = extract_text(result_dom.xpath(author_xpath))        length = extract_text(result_dom.xpath(length_xpath))        if earned:            content = f"{views} views - {rumbles} rumbles - ${earned}"        else:            content = f"{views} views - {rumbles} rumbles"        results.append({            'url': url,            'title': title,            'content': content,            'author': author,            'length': length,            'template': 'videos.html',            'publishedDate': fixed_date,            'thumbnail': thumbnail,        })    return results
 |