# SPDX-License-Identifier: AGPL-3.0-or-later """Springer Nature (science) """ # pylint: disable=missing-function-docstring from datetime import datetime from json import loads from urllib.parse import urlencode from searx import logger from searx.exceptions import SearxEngineAPIException logger = logger.getChild('Springer Nature engine') about = { "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 = True nb_per_page = 10 api_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 params def 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