| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970 | # SPDX-License-Identifier: AGPL-3.0-or-later# lint: pylint"""Springer Nature (science)"""from datetime import datetimefrom json import loadsfrom urllib.parse import urlencodefrom searx.exceptions import SearxEngineAPIExceptionabout = {    "website": 'https://www.springernature.com/',    "wikidata_id": 'Q21096327',    "official_api_documentation": 'https://dev.springernature.com/',    "use_official_api": True,    "require_api_key": True,    "results": 'JSON',}categories = ['science']paging = Truenb_per_page = 10api_key = 'unset'base_url = 'https://api.springernature.com/metadata/json?'def request(query, params):    if api_key == 'unset':        raise SearxEngineAPIException('missing Springer-Nature API key')    args = urlencode({        'q' : query,        's' : nb_per_page * (params['pageno'] - 1),        'p' : nb_per_page,        'api_key' : api_key        })    params['url'] = base_url + args    logger.debug("query_url --> %s", params['url'])    return paramsdef response(resp):    results = []    json_data = loads(resp.text)    for record in json_data['records']:        content = record['abstract'][0:500]        if len(record['abstract']) > len(content):            content += "..."        published = datetime.strptime(record['publicationDate'], '%Y-%m-%d')        metadata = [record[x] for x in [            'publicationName',            'identifier',            'contentType',        ] if record.get(x) is not None]        metadata = ' / '.join(metadata)        if record.get('startingPage') and record.get('endingPage') is not None:            metadata += " (%(startingPage)s-%(endingPage)s)" % record        results.append({            'title': record['title'],            'url': record['url'][0]['value'].replace('http://', 'https://', 1),            'content' : content,            'publishedDate' : published,            'metadata' : metadata        })    return results
 |