| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 | # SPDX-License-Identifier: AGPL-3.0-or-later""" Wikipedia (Web"""from urllib.parse import urlencodefrom json import loadsfrom dateutil import parser# aboutabout = {    "website": 'https://vimeo.com/',    "wikidata_id": 'Q156376',    "official_api_documentation": 'http://developer.vimeo.com/api',    "use_official_api": False,    "require_api_key": False,    "results": 'HTML',}# engine dependent configcategories = ['videos']paging = True# search-urlbase_url = 'https://vimeo.com/'search_url = base_url + '/search/page:{pageno}?{query}'# do search-requestdef request(query, params):    params['url'] = search_url.format(pageno=params['pageno'], query=urlencode({'q': query}))    return params# get response from search-requestdef response(resp):    results = []    data_start_pos = resp.text.find('{"filtered"')    data_end_pos = resp.text.find(';\n', data_start_pos + 1)    data = loads(resp.text[data_start_pos:data_end_pos])    # parse results    for result in data['filtered']['data']:        result = result[result['type']]        videoid = result['uri'].split('/')[-1]        url = base_url + videoid        title = result['name']        thumbnail = result['pictures']['sizes'][-1]['link']        publishedDate = parser.parse(result['created_time'])        # append result        results.append(            {                'url': url,                'title': title,                'content': '',                'template': 'videos.html',                'publishedDate': publishedDate,                'iframe_src': "https://player.vimeo.com/video/" + videoid,                'thumbnail': thumbnail,            }        )    # return results    return results
 |