| 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}'embedded_url = (    '<iframe scrolling="no" frameborder="0" allowTransparency="true" '    + 'data-src="https://www.mixcloud.com/widget/iframe/?feed={url}" width="300" height="300"></iframe>')# 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']        embedded = embedded_url.format(url=url)        publishedDate = parser.parse(result['created_time'])        # append result        results.append(            {'url': url, 'title': title, 'embedded': embedded, 'publishedDate': publishedDate, 'content': content}        )    # return results    return results
 |