| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 | # SPDX-License-Identifier: AGPL-3.0-or-later""" Mixcloud (Music)"""from json import loadsfrom dateutil import parserfrom urllib.parse import urlencode# aboutabout = {    "website": 'https://www.mixcloud.com/',    "wikidata_id": 'Q6883832',    "official_api_documentation": 'http://www.mixcloud.com/developers/',    "use_official_api": True,    "require_api_key": False,    "results": 'JSON',}# engine dependent configcategories = ['music']paging = True# search-urlurl = 'https://api.mixcloud.com/'search_url = url + 'search/?{query}&type=cloudcast&limit=10&offset={offset}'iframe_src = "https://www.mixcloud.com/widget/iframe/?feed={url}"# do search-requestdef request(query, params):    offset = (params['pageno'] - 1) * 10    params['url'] = search_url.format(query=urlencode({'q': query}), offset=offset)    return params# get response from search-requestdef response(resp):    results = []    search_res = loads(resp.text)    # parse results    for result in search_res.get('data', []):        title = result['name']        url = result['url']        content = result['user']['name']        publishedDate = parser.parse(result['created_time'])        # append result        results.append(            {                'url': url,                'title': title,                'iframe_src': iframe_src.format(url=url),                'publishedDate': publishedDate,                'content': content,            }        )    # return results    return results
 |