package net.sourceforge.seqware.common.dao; import io.seqware.common.model.WorkflowRunStatus; import java.util.List; import net.sourceforge.seqware.common.model.File; import net.sourceforge.seqware.common.model.Registration; import net.sourceforge.seqware.common.model.Study; /** * <p> * StudyDAO interface. * </p> * * @author boconnor * @version $Id: $Id */ public interface StudyDAO { /** * <p> * insert. * </p> * * @param sequencerRun * a {@link net.sourceforge.seqware.common.model.Study} object. * @return a {@link java.lang.Integer} object. */ public Integer insert(Study sequencerRun); /** * <p> * insert. * </p> * * @param registration * a {@link net.sourceforge.seqware.common.model.Registration} object. * @param sequencerRun * a {@link net.sourceforge.seqware.common.model.Study} object. * @return a {@link java.lang.Integer} object. */ public Integer insert(Registration registration, Study sequencerRun); /** * <p> * update. * </p> * * @param sequencerRun * a {@link net.sourceforge.seqware.common.model.Study} object. */ public void update(Study sequencerRun); /** * <p> * update. * </p> * * @param registration * a {@link net.sourceforge.seqware.common.model.Registration} object. * @param study * a {@link net.sourceforge.seqware.common.model.Study} object. */ public void update(Registration registration, Study study); /** * <p> * delete. * </p> * * @param study * a {@link net.sourceforge.seqware.common.model.Study} object. */ public void delete(Study study); /** * <p> * merge. * </p> * * @param study * a {@link net.sourceforge.seqware.common.model.Study} object. */ void merge(Study study); /** * <p> * list. * </p> * * @param registration * a {@link net.sourceforge.seqware.common.model.Registration} object. * @param isAcs * a {@link java.lang.Boolean} object. * @return a {@link java.util.List} object. */ public List<Study> list(Registration registration, Boolean isAcs); /** * <p> * listMyShared. * </p> * * @param registration * a {@link net.sourceforge.seqware.common.model.Registration} object. * @param isAcs * a {@link java.lang.Boolean} object. * @return a {@link java.util.List} object. */ public List<Study> listMyShared(Registration registration, Boolean isAcs); /** * <p> * listSharedWithMe. * </p> * * @param registration * a {@link net.sourceforge.seqware.common.model.Registration} object. * @param isAcs * a {@link java.lang.Boolean} object. * @return a {@link java.util.List} object. */ public List<Study> listSharedWithMe(Registration registration, Boolean isAcs); /** * <p> * findByTitle. * </p> * * @param title * a {@link java.lang.String} object. * @return a {@link net.sourceforge.seqware.common.model.Study} object. */ public List<Study> findByTitle(String title); /** * <p> * findByID. * </p> * * @param studyID * a {@link java.lang.Integer} object. * @return a {@link net.sourceforge.seqware.common.model.Study} object. */ public Study findByID(Integer studyID); /** * <p> * getFiles. * </p> * * @param studyId * a {@link java.lang.Integer} object. * @return a {@link java.util.List} object. */ public List<File> getFiles(Integer studyId); /** * <p> * isHasFile. * </p> * * @param studyId * a {@link java.lang.Integer} object. * @return a boolean. */ public boolean isHasFile(Integer studyId); /** * <p> * getFiles. * </p> * * @param studyId * a {@link java.lang.Integer} object. * @param metaType * a {@link java.lang.String} object. * @return a {@link java.util.List} object. */ public List<File> getFiles(Integer studyId, String metaType); /** * <p> * isHasFile. * </p> * * @param studyId * a {@link java.lang.Integer} object. * @param metaType * a {@link java.lang.String} object. * @return a boolean. */ public boolean isHasFile(Integer studyId, String metaType); /** * <p> * listStudyHasFile. * </p> * * @param registration * a {@link net.sourceforge.seqware.common.model.Registration} object. * @param metaType * a {@link java.lang.String} object. * @param iaAsc * a {@link java.lang.Boolean} object. * @return a {@link java.util.List} object. */ public List<Study> listStudyHasFile(Registration registration, String metaType, Boolean iaAsc); /** * <p> * findBySWAccession. * </p> * * @param swAccession * a {@link java.lang.Integer} object. * @return a {@link net.sourceforge.seqware.common.model.Study} object. */ public Study findBySWAccession(Integer swAccession); /** * <p> * findByCriteria. * </p> * * @param criteria * a {@link java.lang.String} object. * @param isCaseSens * a boolean. * @return a {@link java.util.List} object. */ public List<Study> findByCriteria(String criteria, boolean isCaseSens); /** * <p> * findByCriteria. * </p> * * @param criteria * a {@link java.lang.String} object. * @return a {@link java.util.List} object. */ public List<Study> findByCriteria(String criteria); /** * <p> * updateDetached. * </p> * * @param study * a {@link net.sourceforge.seqware.common.model.Study} object. * @return a {@link net.sourceforge.seqware.common.model.Study} object. */ public Study updateDetached(Study study); /** * <p> * updateDetached. * </p> * * @param registration * a {@link net.sourceforge.seqware.common.model.Registration} object. * @param study * a {@link net.sourceforge.seqware.common.model.Study} object. * @return a {@link net.sourceforge.seqware.common.model.Study} object. */ public Study updateDetached(Registration registration, Study study); /** * <p> * findByOwnerID. * </p> * * @param registrationId * a {@link java.lang.Integer} object. * @return a {@link java.util.List} object. */ public List<Study> findByOwnerID(Integer registrationId); /** * <p> * updateOwners. * </p> * * @param swAccession * a {@link java.lang.Integer} object. */ public void updateOwners(Integer swAccession); // // List search(); /** * <p> * list. * </p> * * @return a {@link java.util.List} object. */ public List<Study> list(); /** * <p> * Count the number of workflow runs with the given status, under the given study * </p> * * @param study * the study * @param status * the status of the workflow runs to count * @return the count */ public int getStatusCount(Study study, WorkflowRunStatus status); }