package dao.entities; import java.util.List; import java.util.Map; import java.util.UUID; import java.util.stream.Collectors; import javax.persistence.TypedQuery; import org.hibernate.query.Query; import dao.JpaDao; import entities.DMP; import entities.Project; import entities.UserInfo; import entities.responses.IDLabelPair; public class DMPDaoImpl extends JpaDao implements DMPDao { public DMP loadDetails(DMP t) { // TODO Auto-generated method stub return null; } @Override public List listAllIDs() { String queryString = "SELECT dmp.id FROM DMP dmp"; TypedQuery typedQuery = entityManager.createQuery(queryString, UUID.class); return typedQuery.getResultList(); } @Override public List listAllIDsLabels() { String queryString = "SELECT dmp.id, dmp.label FROM DMP dmp"; Query query = (Query) entityManager.createQuery(queryString); List rows = query.list(); return rows.stream().map(row -> { return new IDLabelPair(row[0].toString(), row[1].toString()); }) .collect(Collectors.toList()); } @Override public List listUserDMPs(String userID) { // String queryString = "select ui from UserInfo ui join UserAuth ui.authentication ua where ua.username=:username"; String queryString = "select ui from UserInfo ui join Project ui.pro.authentication ua where ua.username=:username"; // TypedQuery typedQuery = entityManager.createQuery(queryString, UserInfo.class); // typedQuery.setParameter("username", username); return null; } // @Override // public boolean createFromForm(Map keyVals) { // String query = "insert into DMP () values" // return false; // } }