Source code for oc_ocdm.graph.entities.bibliographic.agent_role

#!/usr/bin/python
# -*- coding: utf-8 -*-
# Copyright (c) 2016, Silvio Peroni <essepuntato@gmail.com>
#
# Permission to use, copy, modify, and/or distribute this software for any purpose
# with or without fee is hereby granted, provided that the above copyright notice
# and this permission notice appear in all copies.
#
# THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
# REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
# FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT,
# OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE,
# DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS
# ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
# SOFTWARE.
from __future__ import annotations

from typing import TYPE_CHECKING

from oc_ocdm.decorators import accepts_only

if TYPE_CHECKING:
    from typing import Optional
    from rdflib import URIRef
    from oc_ocdm.graph.entities.bibliographic.responsible_agent import ResponsibleAgent
from oc_ocdm.graph.graph_entity import GraphEntity
from oc_ocdm.graph.entities.bibliographic_entity import BibliographicEntity


[docs]class AgentRole(BibliographicEntity): """Agent role (short: ar): a particular role held by an agent with respect to a bibliographic resource."""
[docs] @accepts_only('ar') def merge(self, other: AgentRole) -> None: """ The merge operation allows combining two ``AgentRole`` entities into a single one, by marking the second entity as to be deleted while also copying its data into the current ``AgentRole``. Moreover, every triple from the containing ``GraphSet`` referring to the second entity gets "redirected" to the current entity: **every other reference contained inside a different source (e.g. a triplestore) must be manually handled by the user!** In case of functional properties, values from the current entity get overwritten by those coming from the second entity while, in all other cases, values from the second entity are simply appended to those of the current entity. In this context, ``rdfs:label`` is considered as a functional property, while ``rdf:type`` is not. :param other: The entity which will be marked as to be deleted and whose properties will be merged into the current entity. :type other: AgentRole :raises TypeError: if the parameter is of the wrong type :return: None """ super(AgentRole, self).merge(other) next_ar: Optional[AgentRole] = other.get_next() if next_ar is not None: self.has_next(next_ar) resp_agent: Optional[ResponsibleAgent] = other.get_is_held_by() if resp_agent is not None: self.is_held_by(resp_agent) role_type: Optional[URIRef] = other.get_role_type() if role_type is not None: if role_type == GraphEntity.iri_publisher: self.create_publisher() elif role_type == GraphEntity.iri_author: self.create_author() elif role_type == GraphEntity.iri_editor: self.create_editor()
# HAS NEXT (AgentRole)
[docs] def get_next(self) -> Optional[AgentRole]: """ Getter method corresponding to the ``oco:hasNext`` RDF predicate. :return: The requested value if found, None otherwise """ uri: Optional[URIRef] = self._get_uri_reference(GraphEntity.iri_has_next, 'ar') if uri is not None: return self.g_set.add_ar(self.resp_agent, self.source, uri)
[docs] @accepts_only('ar') def has_next(self, ar_res: AgentRole) -> None: """ Setter method corresponding to the ``oco:hasNext`` RDF predicate. **WARNING: this is a functional property, hence any existing value will be overwritten!** `The previous role in a sequence of agent roles of the same type associated with the same bibliographic resource (so as to define, for instance, an ordered list of authors).` :param ar_res: The value that will be set as the object of the property related to this method :type ar_res: AgentRole :raises TypeError: if the parameter is of the wrong type :return: None """ self.remove_next() self.g.add((self.res, GraphEntity.iri_has_next, ar_res.res))
[docs] def remove_next(self) -> None: """ Remover method corresponding to the ``oco:hasNext`` RDF predicate. :return: None """ self.g.remove((self.res, GraphEntity.iri_has_next, None))
# IS HELD BY (ResponsibleAgent)
[docs] def get_is_held_by(self) -> Optional[ResponsibleAgent]: """ Getter method corresponding to the ``pro:isHeldBy`` RDF predicate. :return: The requested value if found, None otherwise """ uri: Optional[URIRef] = self._get_uri_reference(GraphEntity.iri_is_held_by, 'ra') if uri is not None: return self.g_set.add_ra(self.resp_agent, self.source, uri)
[docs] @accepts_only('ra') def is_held_by(self, ra_res: ResponsibleAgent): """ Setter method corresponding to the ``pro:isHeldBy`` RDF predicate. **WARNING: this is a functional property, hence any existing value will be overwritten!** `The agent holding this role with respect to a particular bibliographic resource.` :param ra_res: The value that will be set as the object of the property related to this method :type ra_res: ResponsibleAgent :raises TypeError: if the parameter is of the wrong type :return: None """ self.remove_is_held_by() self.g.add((self.res, GraphEntity.iri_is_held_by, ra_res.res))
[docs] def remove_is_held_by(self) -> None: """ Remover method corresponding to the ``pro:isHeldBy`` RDF predicate. :return: None """ self.g.remove((self.res, GraphEntity.iri_is_held_by, None))
# HAS ROLE TYPE
[docs] def get_role_type(self) -> Optional[URIRef]: """ Getter method corresponding to the ``pro:withRole`` RDF predicate. :return: The requested value if found, None otherwise """ uri: Optional[URIRef] = self._get_uri_reference(GraphEntity.iri_with_role) return uri
[docs] def create_publisher(self) -> None: """ Setter method corresponding to the ``pro:withRole`` RDF predicate. It implicitly sets the object value ``pro:publisher``. **WARNING: this is a functional property, hence any existing value will be overwritten!** `The specific type of role under consideration (e.g. author, editor or publisher).` :return: None """ self.remove_role_type() self.g.add((self.res, GraphEntity.iri_with_role, GraphEntity.iri_publisher))
[docs] def create_author(self) -> None: """ Setter method corresponding to the ``pro:withRole`` RDF predicate. It implicitly sets the object value ``pro:author``. **WARNING: this is a functional property, hence any existing value will be overwritten!** `The specific type of role under consideration (e.g. author, editor or publisher).` :return: None """ self.remove_role_type() self.g.add((self.res, GraphEntity.iri_with_role, GraphEntity.iri_author))
[docs] def create_editor(self) -> None: """ Setter method corresponding to the ``pro:withRole`` RDF predicate. It implicitly sets the object value ``pro:editor``. **WARNING: this is a functional property, hence any existing value will be overwritten!** `The specific type of role under consideration (e.g. author, editor or publisher).` :return: None """ self.remove_role_type() self.g.add((self.res, GraphEntity.iri_with_role, GraphEntity.iri_editor))
[docs] def remove_role_type(self) -> None: """ Remover method corresponding to the ``pro:withRole`` RDF predicate. :return: None """ self.g.remove((self.res, GraphEntity.iri_with_role, None))