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

org.dspace.identifier.dao.impl.DOIDAOImpl Maven / Gradle / Ivy

There is a newer version: 8.0
Show 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.identifier.dao.impl;

import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import javax.persistence.criteria.CriteriaBuilder;
import javax.persistence.criteria.CriteriaQuery;
import javax.persistence.criteria.Predicate;
import javax.persistence.criteria.Root;

import org.dspace.content.DSpaceObject;
import org.dspace.core.AbstractHibernateDAO;
import org.dspace.core.Context;
import org.dspace.identifier.DOI;
import org.dspace.identifier.DOI_;
import org.dspace.identifier.dao.DOIDAO;

/**
 * Hibernate implementation of the Database Access Object interface class for the DOI object.
 * This class is responsible for all database calls for the DOI object and is autowired by Spring.
 * This class should never be accessed directly.
 *
 * @author kevinvandevelde at atmire.com
 */
public class DOIDAOImpl extends AbstractHibernateDAO implements DOIDAO {
    protected DOIDAOImpl() {
        super();
    }

    @Override
    public DOI findByDoi(Context context, String doi) throws SQLException {
        CriteriaBuilder criteriaBuilder = getCriteriaBuilder(context);
        CriteriaQuery criteriaQuery = getCriteriaQuery(criteriaBuilder, DOI.class);
        Root doiRoot = criteriaQuery.from(DOI.class);
        criteriaQuery.select(doiRoot);
        criteriaQuery.where(criteriaBuilder.equal(doiRoot.get(DOI_.doi), doi));
        return uniqueResult(context, criteriaQuery, false, DOI.class);
    }

    @Override
    public DOI findDOIByDSpaceObject(Context context, DSpaceObject dso, List statusToExclude)
        throws SQLException {
        CriteriaBuilder criteriaBuilder = getCriteriaBuilder(context);
        CriteriaQuery criteriaQuery = getCriteriaQuery(criteriaBuilder, DOI.class);
        Root doiRoot = criteriaQuery.from(DOI.class);
        criteriaQuery.select(doiRoot);

        List listToIncludeInOrPredicate = new ArrayList<>(statusToExclude.size() + 1);

        for (Integer status : statusToExclude) {
            listToIncludeInOrPredicate.add(criteriaBuilder.notEqual(doiRoot.get(DOI_.status), status));
        }
        listToIncludeInOrPredicate.add(criteriaBuilder.isNull(doiRoot.get(DOI_.status)));

        Predicate orPredicate = criteriaBuilder.or(listToIncludeInOrPredicate.toArray(new Predicate[] {}));

        criteriaQuery.where(criteriaBuilder.and(orPredicate,
                                                criteriaBuilder.equal(doiRoot.get(DOI_.dSpaceObject), dso)
                            )
        );

        return singleResult(context, criteriaQuery);
    }

    @Override
    public List findByStatus(Context context, List statuses) throws SQLException {
        CriteriaBuilder criteriaBuilder = getCriteriaBuilder(context);
        CriteriaQuery criteriaQuery = getCriteriaQuery(criteriaBuilder, DOI.class);
        Root doiRoot = criteriaQuery.from(DOI.class);
        criteriaQuery.select(doiRoot);
        List orPredicates = new ArrayList<>(statuses.size());
        for (Integer status : statuses) {
            orPredicates.add(criteriaBuilder.equal(doiRoot.get(DOI_.status), status));
        }
        criteriaQuery.where(criteriaBuilder.or(orPredicates.toArray(new Predicate[] {})));
        return list(context, criteriaQuery, false, DOI.class, -1, -1);
    }

    @Override
    public List findSimilarNotInState(Context context, String doi, List excludedStatuses,
                                           boolean dsoNotNull)
        throws SQLException {
        CriteriaBuilder criteriaBuilder = getCriteriaBuilder(context);
        CriteriaQuery criteriaQuery = getCriteriaQuery(criteriaBuilder, DOI.class);
        Root doiRoot = criteriaQuery.from(DOI.class);
        criteriaQuery.select(doiRoot);

        List listToIncludeInOrPredicate = new ArrayList<>(excludedStatuses.size());

        for (Integer status : excludedStatuses) {
            listToIncludeInOrPredicate.add(criteriaBuilder.notEqual(doiRoot.get(DOI_.status), status));
        }

        List listToIncludeInAndPredicate = new ArrayList<>();

        listToIncludeInAndPredicate.add(criteriaBuilder.like(doiRoot.get(DOI_.doi), doi));
        listToIncludeInAndPredicate.add(criteriaBuilder.or(listToIncludeInOrPredicate.toArray(new Predicate[] {})));
        if (dsoNotNull) {
            listToIncludeInAndPredicate.add(criteriaBuilder.isNotNull(doiRoot.get(DOI_.dSpaceObject)));
        }
        criteriaQuery.where(listToIncludeInAndPredicate.toArray(new Predicate[] {}));
        return list(context, criteriaQuery, false, DOI.class, -1, -1);
    }

    @Override
    public DOI findDOIByDSpaceObject(Context context, DSpaceObject dso) throws SQLException {
        CriteriaBuilder criteriaBuilder = getCriteriaBuilder(context);
        CriteriaQuery criteriaQuery = getCriteriaQuery(criteriaBuilder, DOI.class);
        Root doiRoot = criteriaQuery.from(DOI.class);
        criteriaQuery.select(doiRoot);
        criteriaQuery.where(criteriaBuilder.equal(doiRoot.get(DOI_.dSpaceObject), dso));
        return singleResult(context, criteriaQuery);
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy