All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.dspace.content.service.RelationshipService Maven / Gradle / Ivy

The newest version!
/**
 * The contents of this file are subject to the license and copyright
 * detailed in the LICENSE and NOTICE files at the root of the source
 * tree and available online at
 *
 * http://www.dspace.org/license/
 */
package org.dspace.content.service;

import java.sql.SQLException;
import java.util.List;
import java.util.UUID;

import org.dspace.authorize.AuthorizeException;
import org.dspace.content.Item;
import org.dspace.content.Relationship;
import org.dspace.content.Relationship.LatestVersionStatus;
import org.dspace.content.RelationshipType;
import org.dspace.content.dao.pojo.ItemUuidAndRelationshipId;
import org.dspace.core.Context;
import org.dspace.service.DSpaceCRUDService;

/**
 * This Service will use the DAO classes to access the information about Relationships from the database
 */
public interface RelationshipService extends DSpaceCRUDService {

    /**
     * Retrieves the list of Relationships currently in the system for which the given Item is either
     * a leftItem or a rightItem object
     * @param context   The relevant DSpace context
     * @param item      The Item that has to be the left or right item for the relationship to be included in the list
     * @return          The list of relationships for which each relationship adheres to the above listed constraint
     * @throws SQLException If something goes wrong
     */
    public List findByItem(Context context, Item item) throws SQLException;

    /**
     * Retrieves the list of Relationships currently in the system for which the given Item is either
     * a leftItem or a rightItem object
     * @param context         The relevant DSpace context
     * @param item            The Item that has to be the left or right item for the relationship to be
     *                        included in the list
     * @param limit           paging limit
     * @param offset          paging offset
     * @param excludeTilted   If true, excludes tilted relationships
     * @return                The list of relationships for which each relationship adheres to the above
     *                        listed constraint
     * @throws SQLException   If something goes wrong
     */
    List findByItem(Context context, Item item, Integer limit, Integer offset, boolean excludeTilted)
            throws SQLException;

    /**
     * Retrieves the list of Relationships currently in the system for which the given Item is either
     * a leftItem or a rightItem object
     * @param context           The relevant DSpace context
     * @param item              The Item that has to be the left or right item for the relationship to be
     *                          included in the list
     * @param limit             paging limit
     * @param offset            paging offset
     * @param excludeTilted     If true, excludes tilted relationships
     * @param excludeNonLatest  If true, excludes all relationships for which the other item has a more recent version
     *                          that is relevant for this relationship
     * @return                  The list of relationships for which each relationship adheres to the above
     *                          listed constraint
     * @throws SQLException     If something goes wrong
     */
    List findByItem(
        Context context, Item item, Integer limit, Integer offset, boolean excludeTilted, boolean excludeNonLatest
    ) throws SQLException;

    /**
     * Retrieves the full list of relationships currently in the system
     * @param context   The relevant DSpace context
     * @return  The list of all relationships currently in the system
     * @throws SQLException If something goes wrong
     */
    public List findAll(Context context) throws SQLException;

    /**
     * Retrieves the full list of relationships currently in the system
     * @param context   The relevant DSpace context
     * @param limit     paging limit
     * @param offset    paging offset
     * @return  The list of all relationships currently in the system
     * @throws SQLException If something goes wrong
     */
    List findAll(Context context, Integer limit, Integer offset) throws SQLException;

    /**
     * This method creates a relationship object in the database equal to the given relationship param
     * if this is a valid relationship
     * @param context       The relevant DSpace context
     * @param relationship  The relationship that will be created in the database if it is valid
     * @return              The created relationship with updated place variables
     * @throws SQLException         If something goes wrong
     * @throws AuthorizeException   If something goes wrong with authorizations
     */
    public Relationship create(Context context, Relationship relationship) throws SQLException, AuthorizeException;

    /**
     * Move the given relationship to a new leftPlace and/or rightPlace.
     *
     * This will
     *   1. verify whether the move is authorized
     *   2. move the relationship to the specified left/right place
     *   3. update the left/right place of other relationships and/or metadata in order to resolve the move without
     *      leaving any gaps
     *
     * At least one of the new places should be non-null, otherwise no changes will be made.
     *
     * @param context               The relevant DSpace context
     * @param relationship          The Relationship to move
     * @param newLeftPlace          The value to set the leftPlace of this Relationship to
     * @param newRightPlace         The value to set the rightPlace of this Relationship to
     * @return                      The moved relationship with updated place variables
     * @throws SQLException         If something goes wrong
     * @throws AuthorizeException   If the user is not authorized to update the Relationship or its Items
     */
    Relationship move(Context context, Relationship relationship, Integer newLeftPlace, Integer newRightPlace)
            throws SQLException, AuthorizeException;

    /**
     * Move the given relationship to a new leftItem and/or rightItem.
     *
     * This will
     *   1. move the relationship to the last place in its current left or right Item. This ensures that we don't leave
     *      any gaps when moving the relationship to a new Item.
     *      If only one of the relationship's Items is changed,the order of relationships and metadatain the other
     *      will not be affected
     *   2. insert the relationship into the new Item(s)
     *
     * At least one of the new Items should be non-null, otherwise no changes will be made.
     *
     * @param context               The relevant DSpace context
     * @param relationship          The Relationship to move
     * @param newLeftItem           The value to set the leftItem of this Relationship to
     * @param newRightItem          The value to set the rightItem of this Relationship to
     * @return                      The moved relationship with updated left/right Items variables
     * @throws SQLException         If something goes wrong
     * @throws AuthorizeException   If the user is not authorized to update the Relationship or its Items
     */
    Relationship move(Context context, Relationship relationship, Item newLeftItem, Item newRightItem)
            throws SQLException, AuthorizeException;

    /**
     * This method returns a list of Relationships for which the leftItem or rightItem is equal to the given
     * Item object and for which the RelationshipType object is equal to the relationshipType property
     * NOTE: tilted relationships are NEVER excluded when fetching one relationship type
     * @param context           The relevant DSpace context
     * @param item              The Item object to be matched on the leftItem or rightItem for the relationship
     * @param relationshipType  The RelationshipType object that will be used to check the Relationship on
     * @return  The list of Relationship objects that have the given Item object as leftItem or rightItem and
     *          for which the relationshipType property is equal to the given RelationshipType
     * @throws SQLException If something goes wrong
     */
    public List findByItemAndRelationshipType(Context context, Item item,
                                                            RelationshipType relationshipType)
        throws SQLException;

    /**
     * This method returns a list of Relationships for which the leftItem or rightItem is equal to the given
     * Item object and for which the RelationshipType object is equal to the relationshipType property
     * NOTE: tilted relationships are NEVER excluded when fetching one relationship type
     * @param context           The relevant DSpace context
     * @param item              The Item object to be matched on the leftItem or rightItem for the relationship
     * @param relationshipType  The RelationshipType object that will be used to check the Relationship on
     * @return  The list of Relationship objects that have the given Item object as leftItem or rightItem and
     *          for which the relationshipType property is equal to the given RelationshipType
     * @throws SQLException If something goes wrong
     */
    public List findByItemAndRelationshipType(Context context, Item item,
                                                            RelationshipType relationshipType, int limit, int offset)
            throws SQLException;

    /**
     * This method returns a list of Relationships for which the leftItem or rightItem is equal to the given
     * Item object and for which the RelationshipType object is equal to the relationshipType property
     * NOTE: tilted relationships are NEVER excluded when fetching one relationship type
     * @param context           The relevant DSpace context
     * @param item              The Item object to be matched on the leftItem or rightItem for the relationship
     * @param relationshipType  The RelationshipType object that will be used to check the Relationship on
     * @param excludeNonLatest  If true, excludes all relationships for which the other item has a more recent version
     *                          that is relevant for this relationship
     * @return  The list of Relationship objects that have the given Item object as leftItem or rightItem and
     *          for which the relationshipType property is equal to the given RelationshipType
     * @throws SQLException If something goes wrong
     */
    public List findByItemAndRelationshipType(
        Context context, Item item, RelationshipType relationshipType, int limit, int offset, boolean excludeNonLatest
    ) throws SQLException;

    /**
     * This method returns a list of Relationships for which the leftItem or rightItem is equal to the given
     * Item object and for which the RelationshipType object is equal to the relationshipType property
     * NOTE: tilted relationships are NEVER excluded when fetching one relationship type
     * @param context           The relevant DSpace context
     * @param item              The Item object to be matched on the leftItem or rightItem for the relationship
     * @param relationshipType  The RelationshipType object that will be used to check the Relationship on
     * @param isLeft             Is the item left or right
     * @return  The list of Relationship objects that have the given Item object as leftItem or rightItem and
     *          for which the relationshipType property is equal to the given RelationshipType
     * @throws SQLException If something goes wrong
     */
    public List findByItemAndRelationshipType(Context context, Item item,
                                                            RelationshipType relationshipType, boolean isLeft,
                                                            int limit, int offset)
            throws SQLException;

    /**
     * This method returns a list of Relationships for which the leftItem or rightItem is equal to the given
     * Item object and for which the RelationshipType object is equal to the relationshipType property
     * NOTE: tilted relationships are NEVER excluded when fetching one relationship type
     * @param context            The relevant DSpace context
     * @param item               The Item object to be matched on the leftItem or rightItem for the relationship
     * @param relationshipType   The RelationshipType object that will be used to check the Relationship on
     * @param isLeft             Is the item left or right
     * @param excludeNonLatest   If true, excludes all relationships for which the other item has a more recent version
     *                           that is relevant for this relationship
     * @return  The list of Relationship objects that have the given Item object as leftItem or rightItem and
     *          for which the relationshipType property is equal to the given RelationshipType
     * @throws SQLException If something goes wrong
     */
    public List findByItemAndRelationshipType(
        Context context, Item item, RelationshipType relationshipType, boolean isLeft, int limit, int offset,
        boolean excludeNonLatest
    ) throws SQLException;

    /**
     * This method returns the UUIDs of all items that have a relationship with the given item, from the perspective
     * of the other item. In other words, given a relationship with the given item, the given item should have
     * "latest status" in order for the other item uuid to be returned.
     *
     * This method differs from the "excludeNonLatest" property in other methods,
     * because in this method the current item should have "latest status" to return the other item,
     * whereas with "excludeNonLatest" the other item should have "latest status" to be returned.
     *
     * This method is used to index items in solr; when searching for related items of one of the returned uuids,
     * the given item should appear as a search result.
     *
     * NOTE: This method does not return {@link Relationship}s for performance, because doing so would eagerly fetch
     *       the items on both sides, which is unnecessary.
     * NOTE: tilted relationships are NEVER excluded when fetching one relationship type.
     * @param context the DSpace context.
     * @param latestItem the target item; only relationships where this item has "latest status" should be considered.
     * @param relationshipType the relationship type for which relationships should be selected.
     * @param isLeft whether the entity type of the item occurs on the left or right side of the relationship type.
     *               This is redundant in most cases, but necessary because relationship types my have
     *               the same entity type on both sides.
     * @return a list containing pairs of relationship ids and item uuids.
     * @throws SQLException if something goes wrong.
     */
    public List findByLatestItemAndRelationshipType(
        Context context, Item latestItem, RelationshipType relationshipType, boolean isLeft
    ) throws SQLException;

    /**
     * This method will update the given item's metadata order.
     * If the relationships for the item have been modified and will calculate the place based on a
     * metadata field, this function will ensure the place is calculated.
     * @param context           The relevant DSpace context
     * @param relatedItem       The Item for which the list of Relationship location is calculated
     *                          based on a metadata field
     * @throws SQLException     If something goes wrong
     * @throws AuthorizeException
     *                          If the user is not authorized to update the item
     */
    public void updateItem(Context context, Item relatedItem) throws SQLException, AuthorizeException;


    /**
     * This method returns a list of Relationship objects for which the relationshipType property is equal to the given
     * RelationshipType object
     * NOTE: tilted relationships are NEVER excluded when fetching one relationship type
     * @param context           The relevant DSpace context
     * @param relationshipType  The RelationshipType object that will be used to check the Relationship on
     * @return  The list of Relationship objects for which the given RelationshipType object is equal
     *          to the relationshipType property
     * @throws SQLException If something goes wrong
     */
    List findByRelationshipType(Context context, RelationshipType relationshipType) throws SQLException;

    /**
     * This method returns a list of Relationship objects for which the relationshipType property is equal to the given
     * RelationshipType object
     * NOTE: tilted relationships are NEVER excluded when fetching one relationship type
     * @param context           The relevant DSpace context
     * @param relationshipType  The RelationshipType object that will be used to check the Relationship on
     * @param limit             paging limit
     * @param offset            paging offset
     * @return  The list of Relationship objects for which the given RelationshipType object is equal
     *          to the relationshipType property
     * @throws SQLException If something goes wrong
     */
    List findByRelationshipType(Context context, RelationshipType relationshipType, Integer limit,
                                              Integer offset) throws SQLException;

    /**
     * This method is used to construct a Relationship object with all it's variables
     * @param c                   The relevant DSpace context
     * @param leftItem            The leftItem Item object for the relationship
     * @param rightItem           The rightItem Item object for the relationship
     * @param relationshipType    The RelationshipType object for the relationship
     * @param leftPlace           The leftPlace integer for the relationship
     * @param rightPlace          The rightPlace integer for the relationship
     * @param leftwardValue       The leftwardValue string for the relationship
     * @param rightwardValue      The rightwardValue string for the relationship
     * @param latestVersionStatus The latestVersionStatus value for the relationship
     * @return                    The created Relationship object with the given properties
     * @throws AuthorizeException   If something goes wrong
     * @throws SQLException         If something goes wrong
     */
    Relationship create(
        Context c, Item leftItem, Item rightItem, RelationshipType relationshipType, int leftPlace, int rightPlace,
        String leftwardValue, String rightwardValue, LatestVersionStatus latestVersionStatus
    ) throws AuthorizeException, SQLException;

    /**
     * This method is used to construct a Relationship object with all it's variables,
     * except the latest version status
     * @param c                 The relevant DSpace context
     * @param leftItem          The leftItem Item object for the relationship
     * @param rightItem         The rightItem Item object for the relationship
     * @param relationshipType  The RelationshipType object for the relationship
     * @param leftPlace         The leftPlace integer for the relationship
     * @param rightPlace        The rightPlace integer for the relationship
     * @param leftwardValue     The leftwardValue string for the relationship
     * @param rightwardValue    The rightwardValue string for the relationship
     * @return                  The created Relationship object with the given properties
     * @throws AuthorizeException   If something goes wrong
     * @throws SQLException         If something goes wrong
     */
    Relationship create(
        Context c, Item leftItem, Item rightItem, RelationshipType relationshipType, int leftPlace, int rightPlace,
        String leftwardValue, String rightwardValue
    ) throws AuthorizeException, SQLException;


    /**
     * This method is used to construct a Relationship object with all it's variables,
     * except the leftward label, rightward label and latest version status
     * @param c                 The relevant DSpace context
     * @param leftItem          The leftItem Item object for the relationship
     * @param rightItem         The rightItem Item object for the relationship
     * @param relationshipType  The RelationshipType object for the relationship
     * @param leftPlace         The leftPlace integer for the relationship
     * @param rightPlace        The rightPlace integer for the relationship
     * @return                  The created Relationship object with the given properties
     * @throws AuthorizeException   If something goes wrong
     * @throws SQLException         If something goes wrong
     */
    Relationship create(Context c, Item leftItem, Item rightItem, RelationshipType relationshipType,
                        int leftPlace, int rightPlace)
        throws AuthorizeException, SQLException;

    /**
     * This method returns a list of Relationship objects for the given typeName
     * @param context           The relevant DSpace context
     * @param typeName          The leftward or rightward typeName of the relationship type
     * @return  A list of Relationship objects that have the given RelationshipType object as the
     *          relationshipType property
     * @throws SQLException If something goes wrong
     */
    List findByTypeName(Context context, String typeName) throws SQLException;

    /**
     * This method returns a list of Relationship objects for the given typeName
     * @param context           The relevant DSpace context
     * @param typeName          The leftward or rightward typeName of the relationship type
     * @param limit             paging limit
     * @param offset            paging offset
     * @return  A list of Relationship objects that have the given RelationshipType object as the
     *          relationshipType property
     * @throws SQLException If something goes wrong
     */
    List findByTypeName(Context context, String typeName, Integer limit, Integer offset)
            throws SQLException;


    /**
     * counts all relationships
     *
     * @param context DSpace context object
     * @return total relationships
     * @throws SQLException if database error
     */
    int countTotal(Context context) throws SQLException;

    /**
     * Count total number of relationships (rows in relationship table) by a relationship type
     * NOTE: tilted relationships are NEVER excluded when fetching one relationship type
     * @param context context
     * @param relationshipType relationship type to filter by
     * @return total count
     * @throws SQLException if database error
     */
    int countByRelationshipType(Context context, RelationshipType relationshipType) throws SQLException;

    /**
     * This method returns a count of Relationship objects that have the given Item object
     * as a leftItem or a rightItem
     * @param context   The relevant DSpace context
     * @param item      The item that should be either a leftItem or a rightItem of all
     *                  the Relationship objects in the returned list
     * @return          The list of Relationship objects that contain either a left or a
     *                  right item that is equal to the given item
     * @throws SQLException If something goes wrong
     */
    int countByItem(Context context, Item item) throws SQLException;

    /**
     * This method returns a count of Relationship objects that have the given Item object
     * as a leftItem or a rightItem
     * @param context           The relevant DSpace context
     * @param item              The item that should be either a leftItem or a rightItem of all
     *                          the Relationship objects in the returned list
     * @param excludeTilted     if true, excludes tilted relationships
     * @param excludeNonLatest  if true, exclude relationships for which the opposite item is not the latest version
     *                          that is relevant
     * @return          The list of Relationship objects that contain either a left or a
     *                  right item that is equal to the given item
     * @throws SQLException If something goes wrong
     */
    int countByItem(Context context, Item item, boolean excludeTilted, boolean excludeNonLatest) throws SQLException;

    /**
     * Count total number of relationships (rows in relationship table) by a relationship type and a boolean indicating
     * whether the relationship should contain the item on the left side or not
     * NOTE: tilted relationships are NEVER excluded when fetching one relationship type
     * @param context context
     * @param relationshipType relationship type to filter by
     * @param isLeft Indicating whether the counted Relationships should have the given Item on the left side or not
     * @return total count with the given parameters
     * @throws SQLException if database error
     */
    int countByItemAndRelationshipType(Context context, Item item, RelationshipType relationshipType, boolean isLeft)
            throws SQLException;

    /**
     * Count total number of relationships (rows in relationship table) by a relationship type and a boolean indicating
     * whether the relationship should contain the item on the left side or not
     * NOTE: tilted relationships are NEVER excluded when fetching one relationship type
     * @param context           context
     * @param relationshipType  relationship type to filter by
     * @param isLeft            Indicating whether the counted Relationships should have the given Item on the left side
     * @param excludeNonLatest  If true, excludes all relationships for which the other item has a more recent version
     *                          that is relevant for this relationship
     * @return total count with the given parameters
     * @throws SQLException if database error
     */
    int countByItemAndRelationshipType(
        Context context, Item item, RelationshipType relationshipType, boolean isLeft, boolean excludeNonLatest
    ) throws SQLException;

    /**
     * Count total number of relationships (rows in relationship table)
     * by a relationship leftward or rightward typeName
     *
     * @param context context
     * @param typeName typeName of relationship
     * @return total count
     * @throws SQLException if database error
     */
    int countByTypeName(Context context, String typeName)
            throws SQLException;

    /**
     * This method is used to delete a Relationship whilst given the possibility to copy the Virtual Metadata created
     * by this relationship to the left and/or right item
     * @param context           The relevant DSpace context
     * @param relationship      The relationship to be deleted
     * @param copyToLeftItem    A boolean indicating whether we should copy metadata to the left item or not
     * @param copyToRightItem   A boolean indicating whether we should copy metadata to the right item or not
     */
    void delete(Context context, Relationship relationship, boolean copyToLeftItem, boolean copyToRightItem)
        throws SQLException, AuthorizeException;

    /**
     * This method is used to delete a Relationship whilst given the possibility to copy the Virtual Metadata created
     * by this relationship to the left and/or right item.
     * This method will bypass the cardinality checks on the {@link RelationshipType} for the given {@link Relationship}
     * This should only be used during the deletion of items so that the min cardinality check can't disallow items
     * to be deleted
     * @param context           The relevant DSpace context
     * @param relationship      The relationship to be deleted
     * @param copyToLeftItem    A boolean indicating whether we should copy metadata to the left item or not
     * @param copyToRightItem   A boolean indicating whether we should copy metadata to the right item or not
     */
    void forceDelete(Context context, Relationship relationship, boolean copyToLeftItem, boolean copyToRightItem)
        throws SQLException, AuthorizeException;

    /**
     * This method is used to retrieve relationships that match focusItem
     * on the one hand and matches list of related items elsewhere.
     *
     * @param context            DSpace context object
     * @param focusUUID          UUID of Item that will match left side if the param isLeft is true otherwise right side
     * @param relationshipType   Relationship type to filter by
     * @param items              List of UUID that will use to filter other side respect the focusUUID
     * @param isLeft             Indicating whether the counted Relationships should have
     *                           the given Item on the left side or not
     * @param limit              paging limit
     * @param offset             paging offset
     * @return
     * @throws SQLException      If database error
     */
    public List findByItemRelationshipTypeAndRelatedList(Context context, UUID focusUUID,
                RelationshipType relationshipType, List items, boolean isLeft,
                int offset, int limit) throws SQLException;

    /**
     * Count total number of relationships that match focusItem
     * on the one hand and matches list of related items elsewhere.
     *
     * @param context            DSpace context object
     * @param focusUUID          UUID of Item that will match left side if the param isLeft is true otherwise right side
     * @param relationshipType   Relationship type to filter by
     * @param items              List of UUID that will use to filter other side respect the focusUUID
     * @param isLeft             Indicating whether the counted Relationships should have
     *                           the given Item on the left side or not
     * @return
     * @throws SQLException      If database error
     */
    public int countByItemRelationshipTypeAndRelatedList(Context context, UUID focusUUID,
           RelationshipType relationshipType, List items, boolean isLeft) throws SQLException;

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy