Fixes bug on DMP updating modified date.
This commit is contained in:
parent
ae67197818
commit
8705f916b2
|
@ -405,32 +405,41 @@ public class DataManagementPlanManager {
|
||||||
}
|
}
|
||||||
|
|
||||||
public void createOrUpdate(ApiContext apiContext, DataManagementPlan dataManagementPlan, Principal principal) throws Exception {
|
public void createOrUpdate(ApiContext apiContext, DataManagementPlan dataManagementPlan, Principal principal) throws Exception {
|
||||||
|
|
||||||
DMP newDmp = dataManagementPlan.toDataModel();
|
DMP newDmp = dataManagementPlan.toDataModel();
|
||||||
createOrganisationsIfTheyDontExist(newDmp, apiContext.getOperationsContext().getDatabaseRepository().getOrganisationDao());
|
|
||||||
createResearchersIfTheyDontExist(newDmp, apiContext.getOperationsContext().getDatabaseRepository().getResearcherDao());
|
|
||||||
UserInfo user = apiContext.getOperationsContext().getDatabaseRepository().getUserInfoDao().find(principal.getId());
|
UserInfo user = apiContext.getOperationsContext().getDatabaseRepository().getUserInfoDao().find(principal.getId());
|
||||||
createProjectIfItDoesntExist(newDmp, apiContext.getOperationsContext().getDatabaseRepository().getProjectDao(), user);
|
|
||||||
newDmp.setCreator(user);
|
newDmp.setCreator(user);
|
||||||
|
|
||||||
DMP dmp = apiContext.getOperationsContext().getDatabaseRepository().getDmpDao().find(dataManagementPlan.getId());
|
createOrganisationsIfTheyDontExist(newDmp, apiContext.getOperationsContext().getDatabaseRepository().getOrganisationDao());
|
||||||
if (dmp.getCreator().getId().equals(principal.getId())) {
|
createResearchersIfTheyDontExist(newDmp, apiContext.getOperationsContext().getDatabaseRepository().getResearcherDao());
|
||||||
List<UserDMP> userDMPList = dmp.getUsers().stream().collect(Collectors.toList());
|
createProjectIfItDoesntExist(newDmp, apiContext.getOperationsContext().getDatabaseRepository().getProjectDao(), user);
|
||||||
for (UserInfoListingModel userInfoListingModel : dataManagementPlan.getUsers()) {
|
|
||||||
for(UserDMP userDMP : userDMPList) {
|
try {
|
||||||
if (!(userDMP.getUser().getId().equals(userInfoListingModel.getId()))) {
|
DMP dmp = apiContext.getOperationsContext().getDatabaseRepository().getDmpDao().find(dataManagementPlan.getId());
|
||||||
apiContext.getOperationsContext().getDatabaseRepository().getUserDmpDao().delete(userDMP);
|
newDmp.setCreated(dmp.getCreated());
|
||||||
|
if (dmp.getCreator().getId().equals(principal.getId())) {
|
||||||
|
List<UserDMP> userDMPList = dmp.getUsers().stream().collect(Collectors.toList());
|
||||||
|
for (UserInfoListingModel userInfoListingModel : dataManagementPlan.getUsers()) {
|
||||||
|
for(UserDMP userDMP : userDMPList) {
|
||||||
|
if (!(userDMP.getUser().getId().equals(userInfoListingModel.getId()))) {
|
||||||
|
apiContext.getOperationsContext().getDatabaseRepository().getUserDmpDao().delete(userDMP);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} catch (Exception e) {
|
||||||
|
newDmp.setCreated(new Date());
|
||||||
}
|
}
|
||||||
|
|
||||||
newDmp = apiContext.getOperationsContext().getDatabaseRepository().getDmpDao().createOrUpdate(newDmp);
|
newDmp = apiContext.getOperationsContext().getDatabaseRepository().getDmpDao().createOrUpdate(newDmp);
|
||||||
|
|
||||||
if (dataManagementPlan.getStatus() == DMP.DMPStatus.FINALISED.getValue()) {
|
if (dataManagementPlan.getStatus() == DMP.DMPStatus.FINALISED.getValue()) {
|
||||||
apiContext.getOperationsContext().getDatabaseRepository().getDatasetDao()
|
apiContext.getOperationsContext().getDatabaseRepository().getDatasetDao()
|
||||||
.asQueryable().where((builder, root) -> root.get("id").in(dataManagementPlan.getDatasets()
|
.asQueryable().where((builder, root) -> root.get("id").in(dataManagementPlan.getDatasets()
|
||||||
.stream().map(x -> UUID.fromString(x.getId())).collect(Collectors.toList())))
|
.stream().map(x -> UUID.fromString(x.getId())).collect(Collectors.toList())))
|
||||||
.update(root -> root.<Integer>get("status"), Dataset.Status.FINALISED.getValue());
|
.update(root -> root.<Integer>get("status"), Dataset.Status.FINALISED.getValue());
|
||||||
}
|
}
|
||||||
|
|
||||||
if (dataManagementPlan.getAssociatedUsers().size() == 0)
|
if (dataManagementPlan.getAssociatedUsers().size() == 0)
|
||||||
assignUser(newDmp, user, apiContext);
|
assignUser(newDmp, user, apiContext);
|
||||||
}
|
}
|
||||||
|
|
|
@ -36,6 +36,7 @@ public class DataManagementPlan implements DataModel<DMP, DataManagementPlan> {
|
||||||
private List<UserListingModel> associatedUsers;
|
private List<UserListingModel> associatedUsers;
|
||||||
private DataManagementPlanProfile definition;
|
private DataManagementPlanProfile definition;
|
||||||
private eu.eudat.models.data.userinfo.UserInfo creator;
|
private eu.eudat.models.data.userinfo.UserInfo creator;
|
||||||
|
private Date modified;
|
||||||
private Date created;
|
private Date created;
|
||||||
private List<DynamicFieldWithValue> dynamicFields;
|
private List<DynamicFieldWithValue> dynamicFields;
|
||||||
private Map<String, Object> properties;
|
private Map<String, Object> properties;
|
||||||
|
@ -125,6 +126,13 @@ public class DataManagementPlan implements DataModel<DMP, DataManagementPlan> {
|
||||||
this.profiles = profiles;
|
this.profiles = profiles;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Date getModified() {
|
||||||
|
return modified;
|
||||||
|
}
|
||||||
|
public void setModified(Date modified) {
|
||||||
|
this.modified = modified;
|
||||||
|
}
|
||||||
|
|
||||||
public Date getCreated() {
|
public Date getCreated() {
|
||||||
return created;
|
return created;
|
||||||
}
|
}
|
||||||
|
@ -226,6 +234,7 @@ public class DataManagementPlan implements DataModel<DMP, DataManagementPlan> {
|
||||||
}*/
|
}*/
|
||||||
}
|
}
|
||||||
this.datasets = entity.getDataset().stream().map(item -> new DatasetListingModel().fromDataModel(item)).collect(Collectors.toList());
|
this.datasets = entity.getDataset().stream().map(item -> new DatasetListingModel().fromDataModel(item)).collect(Collectors.toList());
|
||||||
|
this.modified = entity.getModified();
|
||||||
this.created = entity.getCreated();
|
this.created = entity.getCreated();
|
||||||
this.description = entity.getDescription();
|
this.description = entity.getDescription();
|
||||||
this.status = entity.getStatus();
|
this.status = entity.getStatus();
|
||||||
|
@ -248,20 +257,11 @@ public class DataManagementPlan implements DataModel<DMP, DataManagementPlan> {
|
||||||
if (this.researchers != null && !this.researchers.isEmpty())
|
if (this.researchers != null && !this.researchers.isEmpty())
|
||||||
dataManagementPlanEntity.setResearchers(new HashSet<>(this.researchers.stream().map(item -> item.toDataModel()).collect(Collectors.toList())));
|
dataManagementPlanEntity.setResearchers(new HashSet<>(this.researchers.stream().map(item -> item.toDataModel()).collect(Collectors.toList())));
|
||||||
dataManagementPlanEntity.setVersion(this.version);
|
dataManagementPlanEntity.setVersion(this.version);
|
||||||
|
|
||||||
dataManagementPlanEntity.setLabel(this.label);
|
dataManagementPlanEntity.setLabel(this.label);
|
||||||
if (this.project != null) dataManagementPlanEntity.setProject(this.project.toDataModel());
|
if (this.project != null) dataManagementPlanEntity.setProject(this.project.toDataModel());
|
||||||
dataManagementPlanEntity.setStatus((short) this.status);
|
dataManagementPlanEntity.setStatus((short) this.status);
|
||||||
dataManagementPlanEntity.setDescription(this.description);
|
dataManagementPlanEntity.setDescription(this.description);
|
||||||
if (this.profiles != null) {
|
if (this.profiles != null) {
|
||||||
/* Document associatedProfileDoc = XmlBuilder.getDocument();
|
|
||||||
Element associatedProfilesElement = associatedProfileDoc.createElement("profiles");
|
|
||||||
for (AssociatedProfile associatedProfile : this.profiles) {
|
|
||||||
associatedProfilesElement.appendChild(associatedProfile.toXml(associatedProfileDoc));
|
|
||||||
}
|
|
||||||
associatedProfileDoc.appendChild(associatedProfilesElement);
|
|
||||||
dataManagementPlanEntity.setAssociatedDmps(XmlBuilder.generateXml(associatedProfileDoc));*/
|
|
||||||
|
|
||||||
Set<DatasetProfile> datasetProfiles = new HashSet<>();
|
Set<DatasetProfile> datasetProfiles = new HashSet<>();
|
||||||
for (AssociatedProfile profile : this.profiles) {
|
for (AssociatedProfile profile : this.profiles) {
|
||||||
datasetProfiles.add(profile.toData());
|
datasetProfiles.add(profile.toData());
|
||||||
|
@ -270,20 +270,11 @@ public class DataManagementPlan implements DataModel<DMP, DataManagementPlan> {
|
||||||
}
|
}
|
||||||
dataManagementPlanEntity.setProperties(this.properties != null ? JSONObject.toJSONString(this.properties) : null);
|
dataManagementPlanEntity.setProperties(this.properties != null ? JSONObject.toJSONString(this.properties) : null);
|
||||||
dataManagementPlanEntity.setGroupId(this.groupId != null ? this.groupId : UUID.randomUUID());
|
dataManagementPlanEntity.setGroupId(this.groupId != null ? this.groupId : UUID.randomUUID());
|
||||||
|
dataManagementPlanEntity.setModified(this.modified != null ? this.modified : new Date());
|
||||||
dataManagementPlanEntity.setCreated(this.created != null ? this.created : new Date());
|
dataManagementPlanEntity.setCreated(this.created != null ? this.created : new Date());
|
||||||
if (this.dynamicFields != null)
|
if (this.dynamicFields != null)
|
||||||
dataManagementPlanEntity.setDmpProperties(JSONObject.toJSONString(this.dynamicFields.stream().filter(item -> item.getValue() != null).collect(Collectors.toMap(DynamicFieldWithValue::getId, DynamicFieldWithValue::getValue))));
|
dataManagementPlanEntity.setDmpProperties(JSONObject.toJSONString(this.dynamicFields.stream().filter(item -> item.getValue() != null).collect(Collectors.toMap(DynamicFieldWithValue::getId, DynamicFieldWithValue::getValue))));
|
||||||
|
|
||||||
/*if (this.associatedUsers != null && !this.associatedUsers.isEmpty()) {
|
|
||||||
List<UserDMP> userDMPList = new LinkedList<>();
|
|
||||||
for(UserListingModel userListingModel: this.associatedUsers) {
|
|
||||||
UserDMP userDMP = new UserDMP();
|
|
||||||
userDMP.setUser(userListingModel.toDataModel());
|
|
||||||
userDMPList.add(userDMP);
|
|
||||||
}
|
|
||||||
dataManagementPlanEntity.setUsers((Set<UserDMP>) userDMPList);
|
|
||||||
}*/
|
|
||||||
|
|
||||||
return dataManagementPlanEntity;
|
return dataManagementPlanEntity;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue