2018-03-21 11:57:56 +01:00
|
|
|
package eu.eudat.data.dao.entities;
|
2017-09-14 12:37:36 +02:00
|
|
|
|
2018-03-21 11:57:56 +01:00
|
|
|
import eu.eudat.data.dao.DatabaseAccess;
|
|
|
|
import eu.eudat.data.dao.criteria.DatasetProfileCriteria;
|
|
|
|
import eu.eudat.data.dao.databaselayer.service.DatabaseService;
|
2021-04-06 18:03:00 +02:00
|
|
|
import eu.eudat.data.entities.DMP;
|
2018-03-21 11:57:56 +01:00
|
|
|
import eu.eudat.data.entities.DatasetProfile;
|
2017-12-21 10:26:11 +01:00
|
|
|
import eu.eudat.queryable.QueryableList;
|
2019-03-26 15:41:50 +01:00
|
|
|
import eu.eudat.queryable.types.FieldSelectionType;
|
|
|
|
import eu.eudat.queryable.types.SelectionField;
|
2017-12-21 10:26:11 +01:00
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
2018-10-02 16:33:58 +02:00
|
|
|
import org.springframework.scheduling.annotation.Async;
|
2017-12-15 00:01:26 +01:00
|
|
|
import org.springframework.stereotype.Component;
|
2017-09-14 12:37:36 +02:00
|
|
|
|
2021-04-06 18:03:00 +02:00
|
|
|
import javax.persistence.criteria.Join;
|
2019-05-28 09:22:58 +02:00
|
|
|
import javax.persistence.criteria.JoinType;
|
2019-03-26 15:41:50 +01:00
|
|
|
import java.util.Arrays;
|
2021-04-06 18:03:00 +02:00
|
|
|
import java.util.List;
|
2018-02-16 11:34:02 +01:00
|
|
|
import java.util.UUID;
|
2018-02-21 11:07:31 +01:00
|
|
|
import java.util.concurrent.CompletableFuture;
|
2018-02-16 11:34:02 +01:00
|
|
|
|
2017-12-15 00:01:26 +01:00
|
|
|
@Component("datasetProfileDao")
|
2018-01-25 16:24:21 +01:00
|
|
|
public class DatasetProfileDaoImpl extends DatabaseAccess<DatasetProfile> implements DatasetProfileDao {
|
2017-09-14 12:37:36 +02:00
|
|
|
|
2018-02-16 11:34:02 +01:00
|
|
|
@Autowired
|
|
|
|
public DatasetProfileDaoImpl(DatabaseService<DatasetProfile> databaseService) {
|
2018-05-28 11:50:42 +02:00
|
|
|
super(databaseService);
|
2018-02-16 11:34:02 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public QueryableList<DatasetProfile> getWithCriteria(DatasetProfileCriteria criteria) {
|
|
|
|
QueryableList<DatasetProfile> query = getDatabaseService().getQueryable(DatasetProfile.class);
|
|
|
|
if (criteria.getLike() != null && !criteria.getLike().isEmpty())
|
2018-10-09 10:14:29 +02:00
|
|
|
query.where((builder, root) -> builder.like(builder.upper(root.get("label")), "%" + criteria.getLike().toUpperCase() + "%"));
|
2019-03-26 15:41:50 +01:00
|
|
|
if (!criteria.getAllVersions())
|
|
|
|
query.initSubQuery(String.class).where((builder, root) -> builder.equal(root.get("version"),
|
|
|
|
query.<String>subQueryMax((builder1, externalRoot, nestedRoot) -> builder1.equal(externalRoot.get("groupId"),
|
|
|
|
nestedRoot.get("groupId")), Arrays.asList(new SelectionField(FieldSelectionType.FIELD, "version")), String.class)));
|
|
|
|
if (criteria.getGroupIds() != null && !criteria.getGroupIds().isEmpty())
|
|
|
|
query.where((builder, root) -> root.get("groupId").in(criteria.getGroupIds()));
|
2019-05-28 09:22:58 +02:00
|
|
|
if (criteria.getFilter() != null && criteria.getUserId() != null) {
|
|
|
|
if (criteria.getFilter().equals(DatasetProfileCriteria.DatasetProfileFilter.DMPs.getValue())) {
|
|
|
|
query.initSubQuery(UUID.class).where((builder, root) ->
|
|
|
|
builder.and(root.get("id").in(
|
|
|
|
query.subQuery((builder1, root1) -> builder1.equal(root1.join("dmps", JoinType.LEFT).join("users", JoinType.LEFT).join("user", JoinType.LEFT).get("id"), criteria.getUserId()),
|
|
|
|
Arrays.asList(new SelectionField(FieldSelectionType.FIELD, "id")))),
|
|
|
|
builder.notEqual(root.get("id"), criteria.getUserId())));
|
|
|
|
//query.where(((builder, root) -> builder.equal(root.join("dmps", JoinType.LEFT).join("users", JoinType.LEFT).join("user", JoinType.LEFT).get("id"), criteria.getUserId())));
|
|
|
|
}
|
2019-06-12 11:10:46 +02:00
|
|
|
if (criteria.getFilter().equals(DatasetProfileCriteria.DatasetProfileFilter.Datasets.getValue())) {
|
|
|
|
query.initSubQuery(UUID.class).where((builder, root) ->
|
|
|
|
builder.and(root.get("id").in(
|
|
|
|
query.subQuery((builder1, root1) -> builder1.equal(root1.join("dataset", JoinType.LEFT).join("dmp", JoinType.LEFT).join("users", JoinType.LEFT).join("user", JoinType.LEFT).get("id"), criteria.getUserId()),
|
|
|
|
Arrays.asList(new SelectionField(FieldSelectionType.FIELD, "id")))),
|
|
|
|
builder.notEqual(root.get("id"), criteria.getUserId())));
|
|
|
|
}
|
2019-05-28 09:22:58 +02:00
|
|
|
}
|
2020-05-08 17:27:16 +02:00
|
|
|
if (criteria.getStatus() != null) {
|
|
|
|
query.where(((builder, root) -> builder.equal(root.get("status"), criteria.getStatus())));
|
|
|
|
}
|
2020-01-20 17:11:35 +01:00
|
|
|
if (criteria.getFinalized()) {
|
|
|
|
query.where(((builder, root) -> builder.equal(root.get("status"), DatasetProfile.Status.FINALIZED.getValue())));
|
|
|
|
} else {
|
|
|
|
query.where(((builder, root) -> builder.notEqual(root.get("status"), DatasetProfile.Status.DELETED.getValue())));
|
|
|
|
}
|
2018-02-16 11:34:02 +01:00
|
|
|
return query;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public DatasetProfile createOrUpdate(DatasetProfile item) {
|
|
|
|
return this.getDatabaseService().createOrUpdate(item, DatasetProfile.class);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public DatasetProfile find(UUID id) {
|
|
|
|
return getDatabaseService().getQueryable(DatasetProfile.class).where((builder, root) -> builder.equal(root.get("id"), id)).getSingle();
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public QueryableList<DatasetProfile> getAll() {
|
|
|
|
return getDatabaseService().getQueryable(DatasetProfile.class);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void delete(DatasetProfile item) {
|
|
|
|
this.getDatabaseService().delete(item);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public QueryableList<DatasetProfile> asQueryable() {
|
|
|
|
return this.getDatabaseService().getQueryable(DatasetProfile.class);
|
|
|
|
}
|
2018-02-21 11:07:31 +01:00
|
|
|
|
2018-10-02 16:33:58 +02:00
|
|
|
@Async
|
2018-02-21 11:07:31 +01:00
|
|
|
@Override
|
|
|
|
public CompletableFuture<DatasetProfile> createOrUpdateAsync(DatasetProfile item) {
|
|
|
|
return CompletableFuture.supplyAsync(() -> this.createOrUpdate(item));
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public DatasetProfile find(UUID id, String hint) {
|
|
|
|
throw new UnsupportedOperationException();
|
|
|
|
}
|
2021-04-06 18:03:00 +02:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public QueryableList<DatasetProfile> getAuthenticated(QueryableList<DatasetProfile> query, UUID principal, List<Integer> roles) {
|
|
|
|
if (roles != null && !roles.isEmpty()) {
|
|
|
|
query.where((builder, root) -> {
|
|
|
|
Join userJoin = root.join("users", JoinType.LEFT);
|
|
|
|
return builder.and(builder.equal(userJoin.join("user", JoinType.LEFT).get("id"), principal), userJoin.get("role").in(roles));
|
|
|
|
});
|
|
|
|
} else {
|
|
|
|
query.where((builder, root) -> builder.equal(root.join("users", JoinType.LEFT).join("user", JoinType.LEFT).get("id"), principal));
|
|
|
|
}
|
|
|
|
|
|
|
|
return query;
|
|
|
|
}
|
2017-09-14 12:37:36 +02:00
|
|
|
}
|