Source code for inspirehep.modules.authors.rest.publications

# -*- coding: utf-8 -*-
#
# This file is part of INSPIRE.
# Copyright (C) 2014-2017 CERN.
#
# INSPIRE is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# INSPIRE is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with INSPIRE. If not, see <http://www.gnu.org/licenses/>.
#
# In applying this license, CERN does not waive the privileges and immunities
# granted to it by virtue of its status as an Intergovernmental Organization
# or submit itself to any jurisdiction.

from __future__ import absolute_import, division, print_function

import json

from elasticsearch_dsl import Q

from inspirehep.modules.search import LiteratureSearch
from inspirehep.utils.record import get_title


[docs]class AuthorAPIPublications(object): """API endpoint for author collection returning publications."""
[docs] def serialize(self, pid, record, links_factory=None): """Return a list of publications for a given author recid. :param pid: Persistent identifier instance. :param record: Record instance. :param links_factory: Factory function for the link generation, which are added to the response. """ author_pid = pid.pid_value publications = [] query = Q('match', authors__recid=author_pid) search = LiteratureSearch().query('nested', path='authors', query=query)\ .params(_source=[ 'accelerator_experiments', 'citation_count', 'control_number', 'earliest_date', 'facet_inspire_doc_type', 'keywords', 'publication_info', 'self', 'titles', ]) for result in search.scan(): result_source = result.to_dict() publication = {} publication['id'] = int(result_source['control_number']) publication['record'] = result_source['self'] publication['title'] = get_title(result_source) # Get the earliest date. try: publication['date'] = result_source['earliest_date'] except KeyError: pass # Get publication type. try: publication['type'] = result_source.get( 'facet_inspire_doc_type', [])[0] except IndexError: pass # Get citation count. try: publication['citations'] = result_source['citation_count'] except KeyError: pass # Get journal. try: publication['journal'] = {} publication['journal']['title'] = result_source.get( 'publication_info', [])[0]['journal_title'] # Get journal id and $self. try: publication['journal']['id'] = result_source.get( 'publication_info', [])[0]['journal_recid'] publication['journal']['record'] = result_source.get( 'publication_info', [])[0]['journal_record'] except KeyError: pass except (IndexError, KeyError): del publication['journal'] # Get collaborations. collaborations = set() for experiment in result_source.get('accelerator_experiments', []): collaborations.add(experiment.get('experiment')) if collaborations: publication['collaborations'] = list(collaborations) publications.append(publication) return json.dumps(publications)