package eu.eudat.dao.entities; import eu.eudat.dao.DatabaseAccess; import eu.eudat.dao.databaselayer.service.DatabaseService; import eu.eudat.entities.Project; import eu.eudat.entities.UserInfo; import eu.eudat.models.criteria.ProjectCriteria; import eu.eudat.queryable.QueryableList; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import java.util.UUID; @Component("projectDao") public class ProjectDaoImpl extends DatabaseAccess implements ProjectDao { @Autowired public ProjectDaoImpl(DatabaseService databaseService) { this.setDatabaseService(databaseService); } @Override public QueryableList getWithCriteria(ProjectCriteria criteria) { QueryableList query = getDatabaseService().getQueryable(Project.class); if (criteria.getLike() != null && !criteria.getLike().isEmpty()) query.where((builder, root) -> builder.like(root.get("label"), "%" + criteria.getLike() + "%")); if (criteria.getPeriodEnd() != null) query.where((builder, root) -> builder.lessThan(root.get("enddate"), criteria.getPeriodEnd())); if (criteria.getPeriodStart() != null) query.where((builder, root) -> builder.greaterThan(root.get("startdate"), criteria.getPeriodStart())); if (criteria.getReference() != null) query.where((builder, root) -> builder.equal(root.get("reference"), criteria.getReference())); query.where((builder, root) -> builder.notEqual(root.get("status"), Project.Status.DELETED.getValue())); return query; } @Override public Project createOrUpdate(Project item) { return getDatabaseService().createOrUpdate(item, Project.class); } @Override public Project find(UUID id) { return getDatabaseService().getQueryable(Project.class).where((builder, root) -> builder.equal((root.get("id")), id)).getSingle(); } @Override public void delete(Project item) { this.getDatabaseService().delete(item); } @Override public QueryableList asQueryable() { return this.getDatabaseService().getQueryable(Project.class); } public QueryableList getAuthenticated(QueryableList query, UserInfo principal) { query.where((builder, root) -> builder.equal(root.get("creator"), principal)); return query; } }