2017-10-12 14:04:38 +02:00
|
|
|
package rest.entities;
|
2017-10-04 11:48:21 +02:00
|
|
|
|
2017-11-03 18:55:04 +01:00
|
|
|
import java.util.Date;
|
2017-12-11 10:48:18 +01:00
|
|
|
import java.util.HashSet;
|
2017-10-04 11:48:21 +02:00
|
|
|
import java.util.List;
|
|
|
|
import java.util.UUID;
|
|
|
|
|
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
import org.springframework.http.HttpStatus;
|
|
|
|
import org.springframework.http.ResponseEntity;
|
2017-11-17 01:43:16 +01:00
|
|
|
import org.springframework.security.core.context.SecurityContextHolder;
|
2017-10-04 11:48:21 +02:00
|
|
|
import org.springframework.web.bind.annotation.CrossOrigin;
|
|
|
|
import org.springframework.web.bind.annotation.PathVariable;
|
|
|
|
import org.springframework.web.bind.annotation.RequestBody;
|
|
|
|
import org.springframework.web.bind.annotation.RequestMapping;
|
|
|
|
import org.springframework.web.bind.annotation.RequestMethod;
|
|
|
|
import org.springframework.web.bind.annotation.RequestParam;
|
|
|
|
import org.springframework.web.bind.annotation.ResponseBody;
|
|
|
|
import org.springframework.web.bind.annotation.RestController;
|
|
|
|
|
|
|
|
import dao.entities.DMPDao;
|
|
|
|
import dao.entities.DMPProfileDao;
|
|
|
|
import dao.entities.DataRepositoryDao;
|
|
|
|
import dao.entities.DatasetDao;
|
|
|
|
import dao.entities.DatasetProfileDao;
|
|
|
|
import dao.entities.DatasetProfileRulesetDao;
|
|
|
|
import dao.entities.DatasetProfileViewstyleDao;
|
|
|
|
import dao.entities.OrganisationDao;
|
|
|
|
import dao.entities.ProjectDao;
|
|
|
|
import dao.entities.RegistryDao;
|
|
|
|
import dao.entities.ResearcherDao;
|
|
|
|
import dao.entities.ServiceDao;
|
2017-11-17 01:43:16 +01:00
|
|
|
import dao.entities.UserInfoDao;
|
2017-10-04 11:48:21 +02:00
|
|
|
import entities.DMP;
|
|
|
|
import entities.Dataset;
|
|
|
|
import entities.DatasetProfile;
|
2017-11-17 01:43:16 +01:00
|
|
|
import entities.UserInfo;
|
2017-11-02 15:25:05 +01:00
|
|
|
import helpers.SafeCleanAttribs;
|
2017-10-20 17:11:40 +02:00
|
|
|
import helpers.SerializerProvider;
|
2017-12-09 23:31:07 +01:00
|
|
|
import models.criteria.DataRepositoryCriteria;
|
|
|
|
import models.criteria.RegistryCriteria;
|
|
|
|
import models.criteria.ServiceCriteria;
|
2017-10-04 11:48:21 +02:00
|
|
|
import responses.RestResponse;
|
2017-12-11 10:48:18 +01:00
|
|
|
import utilities.builders.DomainModelConverter;
|
2017-10-04 11:48:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
@RestController
|
|
|
|
@CrossOrigin
|
|
|
|
public class Datasets {
|
|
|
|
|
|
|
|
@Autowired private DataRepositoryDao dataRepositoryDao;
|
|
|
|
@Autowired private DatasetDao datasetDao;
|
|
|
|
@Autowired private DatasetProfileDao datasetProfileDao;
|
|
|
|
@Autowired private DatasetProfileRulesetDao datasetProfileRulesetDao;
|
|
|
|
@Autowired private DatasetProfileViewstyleDao datasetProfileViewstyleDao;
|
|
|
|
@Autowired private DMPDao dMPDao;
|
|
|
|
@Autowired private DMPProfileDao dMPProfileDao;
|
|
|
|
@Autowired private OrganisationDao organisationDao;
|
|
|
|
@Autowired private ProjectDao projectDao;
|
|
|
|
@Autowired private RegistryDao registryDao;
|
|
|
|
@Autowired private ResearcherDao researcherDao;
|
|
|
|
@Autowired private ServiceDao serviceDao;
|
2017-11-17 01:43:16 +01:00
|
|
|
@Autowired private UserInfoDao userInfoDao;
|
2017-10-04 11:48:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
// FETCH BY DATASET(S)
|
|
|
|
|
2017-10-23 18:06:24 +02:00
|
|
|
|
|
|
|
@RequestMapping(method = RequestMethod.GET, value = { "/datasets" })
|
2017-10-04 11:48:21 +02:00
|
|
|
public @ResponseBody ResponseEntity<Object> listDatasets(){
|
|
|
|
try {
|
|
|
|
List<UUID> allIDs = datasetDao.listAllIDs();
|
2017-10-27 12:52:12 +02:00
|
|
|
return ResponseEntity.status(HttpStatus.OK).body(SerializerProvider.toJson(allIDs));
|
2017-10-04 11:48:21 +02:00
|
|
|
}
|
|
|
|
catch(Exception ex) {
|
|
|
|
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("Serialization issue: "+ex.getMessage());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-10-23 18:06:24 +02:00
|
|
|
@RequestMapping(method = RequestMethod.GET, value = { "/datasets/{id}" })
|
2017-10-04 11:48:21 +02:00
|
|
|
public @ResponseBody ResponseEntity<Object> getDataset(@PathVariable("id") String id) {
|
|
|
|
try {
|
|
|
|
Dataset ds = datasetDao.read(UUID.fromString(id));
|
2017-12-11 10:48:18 +01:00
|
|
|
models.dataset.Dataset dataset = new models.dataset.Dataset();
|
|
|
|
dataset.fromDataModel(ds);
|
|
|
|
return ResponseEntity.status(HttpStatus.OK).body(SerializerProvider.toJson(dataset));
|
2017-10-04 11:48:21 +02:00
|
|
|
}
|
|
|
|
catch(Exception ex) {
|
|
|
|
return ResponseEntity.status(HttpStatus.BAD_REQUEST).body("Erroneous input: "+ex.getMessage());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* This should be called on extreme cases. It's computationally intensive
|
|
|
|
*/
|
2017-10-23 18:06:24 +02:00
|
|
|
@RequestMapping(method = RequestMethod.GET, value = { "/dataset/getAll" })
|
2017-10-04 11:48:21 +02:00
|
|
|
public @ResponseBody ResponseEntity<Object> getAllDatasets(){
|
2017-10-20 12:03:55 +02:00
|
|
|
|
2017-10-04 11:48:21 +02:00
|
|
|
try {
|
|
|
|
List<Dataset> allDatasets = datasetDao.getAll();
|
2017-10-27 12:52:12 +02:00
|
|
|
return new ResponseEntity<Object>(SerializerProvider.toJson(allDatasets), HttpStatus.OK);
|
2017-10-04 11:48:21 +02:00
|
|
|
}
|
|
|
|
catch(Exception ex) {
|
2017-10-24 18:33:51 +02:00
|
|
|
ex.printStackTrace();
|
2017-10-20 12:03:55 +02:00
|
|
|
return new ResponseEntity<>(null, HttpStatus.INTERNAL_SERVER_ERROR);
|
2017-10-04 11:48:21 +02:00
|
|
|
}
|
2017-10-20 12:03:55 +02:00
|
|
|
|
2017-10-04 11:48:21 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-11-02 15:25:05 +01:00
|
|
|
@RequestMapping(method = RequestMethod.POST, value = { "/dataset/create" }, consumes = "application/json", produces="application/json")
|
2017-12-08 15:52:12 +01:00
|
|
|
public @ResponseBody ResponseEntity<Object> createDataset(@RequestBody models.dataset.Dataset modeldataset) {
|
|
|
|
|
2017-11-17 01:43:16 +01:00
|
|
|
String userID = null;
|
|
|
|
try {
|
|
|
|
userID = SecurityContextHolder.getContext().getAuthentication().getPrincipal().toString();
|
|
|
|
} catch(NullPointerException ex) {
|
|
|
|
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("You have not logged in. You shouldn't be here");
|
|
|
|
}
|
|
|
|
|
|
|
|
UserInfo userInfo = userInfoDao.read(UUID.fromString(userID));
|
|
|
|
|
|
|
|
if(userInfo==null) //this should normally never happer
|
|
|
|
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("There's no such a user on the system. You shouldn't be here");
|
|
|
|
|
|
|
|
|
2017-12-08 15:52:12 +01:00
|
|
|
Dataset dataset = modeldataset.toDataModel();
|
|
|
|
if(dataset.getDataRepositories()!=null&&!dataset.getDataRepositories().isEmpty()){
|
|
|
|
for(entities.DataRepository dataRepo : dataset.getDataRepositories()){
|
|
|
|
DataRepositoryCriteria criteria = new DataRepositoryCriteria();
|
|
|
|
criteria.setLike(dataRepo.getReference());
|
|
|
|
List<entities.DataRepository> entries = this.dataRepositoryDao.listBy(criteria);
|
|
|
|
if(entries!=null&&!entries.isEmpty())dataRepo.setId(entries.get(0).getId());
|
|
|
|
else dataRepo = this.dataRepositoryDao.create(dataRepo);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if(dataset.getServices()!=null&&!dataset.getServices().isEmpty()){
|
|
|
|
for(entities.Service service : dataset.getServices()){
|
|
|
|
ServiceCriteria criteria = new ServiceCriteria();
|
|
|
|
criteria.setLike(service.getReference());
|
|
|
|
List<entities.Service> entries = this.serviceDao.listBy(criteria);
|
|
|
|
if(entries!=null&&!entries.isEmpty())service.setId(entries.get(0).getId());
|
|
|
|
else service = this.serviceDao.create(service);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if(dataset.getRegistries()!=null&&!dataset.getRegistries().isEmpty()){
|
|
|
|
for(entities.Registry registry : dataset.getRegistries()){
|
|
|
|
RegistryCriteria criteria = new RegistryCriteria();
|
|
|
|
criteria.setLike(registry.getReference());
|
|
|
|
List<entities.Registry> entries = this.registryDao.listBy(criteria);
|
|
|
|
if(entries!=null&&!entries.isEmpty())registry.setId( entries.get(0).getId());
|
|
|
|
else registry = this.registryDao.create(registry);
|
|
|
|
}
|
|
|
|
}
|
2017-11-17 01:43:16 +01:00
|
|
|
|
2017-10-23 18:06:24 +02:00
|
|
|
dataset.setId(null);
|
2017-11-03 18:55:04 +01:00
|
|
|
dataset.setCreated(new Date());
|
|
|
|
dataset.setModified(new Date());
|
|
|
|
dataset.setStatus(new Short("0"));
|
2017-11-17 01:43:16 +01:00
|
|
|
dataset.setCreator(userInfo);
|
2017-11-17 02:16:09 +01:00
|
|
|
if("".equals(dataset.getReference())) dataset.setReference(null);
|
|
|
|
if("".equals(dataset.getProperties())) dataset.setProperties(null);
|
|
|
|
|
2017-10-04 11:48:21 +02:00
|
|
|
try {
|
2017-10-23 18:06:24 +02:00
|
|
|
dataset = datasetDao.create(dataset);
|
2017-10-27 12:52:12 +02:00
|
|
|
return ResponseEntity.status(HttpStatus.CREATED).body(SerializerProvider.toJson(dataset));
|
2017-10-04 11:48:21 +02:00
|
|
|
}
|
|
|
|
catch(Exception e) {
|
2017-11-17 02:16:09 +01:00
|
|
|
e.printStackTrace();
|
2017-10-23 18:06:24 +02:00
|
|
|
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("Could not create or update Dataset! Reason: " + e.getMessage());
|
2017-10-04 11:48:21 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-11-02 15:25:05 +01:00
|
|
|
@RequestMapping(method = RequestMethod.POST, value = { "/dataset/update" }, consumes = "application/json", produces="application/json")
|
2017-12-11 10:48:18 +01:00
|
|
|
public @ResponseBody ResponseEntity<Object> updateDataset(@RequestBody models.dataset.Dataset modeldataset) {
|
2017-11-02 15:25:05 +01:00
|
|
|
|
2017-12-11 10:48:18 +01:00
|
|
|
Dataset dataset = modeldataset.toDataModel();
|
|
|
|
|
|
|
|
if(dataset.getDataRepositories()!=null&&!dataset.getDataRepositories().isEmpty()){
|
|
|
|
for(entities.DataRepository dataRepo : dataset.getDataRepositories()){
|
|
|
|
DataRepositoryCriteria criteria = new DataRepositoryCriteria();
|
|
|
|
criteria.setLike(dataRepo.getReference());
|
|
|
|
List<entities.DataRepository> entries = this.dataRepositoryDao.listBy(criteria);
|
|
|
|
if(entries!=null&&!entries.isEmpty())dataRepo.setId(entries.get(0).getId());
|
|
|
|
else dataRepo = this.dataRepositoryDao.create(dataRepo);
|
|
|
|
}
|
2017-11-02 15:25:05 +01:00
|
|
|
}
|
|
|
|
|
2017-12-11 10:48:18 +01:00
|
|
|
if(dataset.getServices()!=null&&!dataset.getServices().isEmpty()){
|
|
|
|
for(entities.Service service : dataset.getServices()){
|
|
|
|
ServiceCriteria criteria = new ServiceCriteria();
|
|
|
|
criteria.setLike(service.getReference());
|
|
|
|
List<entities.Service> entries = this.serviceDao.listBy(criteria);
|
|
|
|
if(entries!=null&&!entries.isEmpty())service.setId(entries.get(0).getId());
|
|
|
|
else service = this.serviceDao.create(service);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if(dataset.getRegistries()!=null&&!dataset.getRegistries().isEmpty()){
|
|
|
|
for(entities.Registry registry : dataset.getRegistries()){
|
|
|
|
RegistryCriteria criteria = new RegistryCriteria();
|
|
|
|
criteria.setLike(registry.getReference());
|
|
|
|
List<entities.Registry> entries = this.registryDao.listBy(criteria);
|
|
|
|
if(entries!=null&&!entries.isEmpty())registry.setId( entries.get(0).getId());
|
|
|
|
else registry = this.registryDao.create(registry);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Dataset olddataset = datasetDao.read(modeldataset.getId());
|
|
|
|
|
|
|
|
olddataset.getServices().clear();
|
|
|
|
olddataset.setServices(dataset.getServices());
|
|
|
|
|
|
|
|
olddataset.getDataRepositories().clear();
|
|
|
|
olddataset.setDataRepositories(dataset.getDataRepositories());
|
|
|
|
olddataset.getRegistries().clear();
|
|
|
|
olddataset.setRegistries(dataset.getRegistries());
|
|
|
|
|
|
|
|
olddataset.setLabel(modeldataset.getLabel());
|
|
|
|
olddataset.setDescription(modeldataset.getDescription());
|
|
|
|
//SafeCleanAttribs.clean(dataset);
|
2017-10-23 18:06:24 +02:00
|
|
|
|
2017-11-17 02:16:09 +01:00
|
|
|
if("".equals(dataset.getReference())) dataset.setReference(null);
|
|
|
|
if("".equals(dataset.getProperties())) dataset.setProperties(null);
|
|
|
|
|
2017-10-23 18:06:24 +02:00
|
|
|
try {
|
2017-12-11 10:48:18 +01:00
|
|
|
dataset = datasetDao.update(olddataset);
|
2017-11-02 15:25:05 +01:00
|
|
|
return ResponseEntity.status(HttpStatus.CREATED).body(SerializerProvider.toJson(dataset));
|
2017-10-23 18:06:24 +02:00
|
|
|
}
|
|
|
|
catch(Exception ex) {
|
|
|
|
ex.printStackTrace();
|
|
|
|
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("Could not create or update Dataset! Reason: " + ex.getMessage());
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2017-10-06 19:20:05 +02:00
|
|
|
|
|
|
|
|
2017-10-23 18:06:24 +02:00
|
|
|
@RequestMapping(method = RequestMethod.POST, value = { "/dataset/delete" }, consumes = "application/json")
|
2017-10-04 11:48:21 +02:00
|
|
|
public @ResponseBody ResponseEntity<Object> deleteDataset(@RequestBody Dataset dataset) {
|
|
|
|
|
|
|
|
//if we want to make sure it won't cascade up to other (child) components, we can just unhook them by setting them = new ones
|
|
|
|
// e.g: DMP dmp = new DMP() and then dataset.setDMP(dmp)
|
|
|
|
try {
|
|
|
|
datasetDao.delete(dataset);
|
|
|
|
RestResponse rr = new RestResponse("Deleted dataset with id: "+dataset.getId().toString(), dataset.getId().toString());
|
|
|
|
return ResponseEntity.status(HttpStatus.OK).body(rr.toString());
|
|
|
|
}
|
|
|
|
catch(Exception e) {
|
|
|
|
e.printStackTrace();
|
|
|
|
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("Could not delete Dataset! Reason: " + e.getMessage());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-11-02 17:41:24 +01:00
|
|
|
|
|
|
|
|
|
|
|
@RequestMapping(method = RequestMethod.POST, value = { "/dataset/softdelete" }, consumes = "application/json", produces="text/plain")
|
|
|
|
public @ResponseBody ResponseEntity<Object> softDelete(@RequestBody Dataset dataset) {
|
|
|
|
try {
|
2017-12-11 10:48:18 +01:00
|
|
|
|
|
|
|
Dataset d = datasetDao.read(dataset.getId());
|
|
|
|
d.setStatus(new Short("-1"));
|
|
|
|
dataset = datasetDao.update(dataset);
|
2017-12-12 15:00:01 +01:00
|
|
|
return ResponseEntity.status(HttpStatus.OK).body("{\"msg\":\"Deleted dataset!\"");
|
2017-11-02 17:41:24 +01:00
|
|
|
} catch (Exception e) {
|
|
|
|
e.printStackTrace();
|
|
|
|
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("{\"msg\":\"Could not soft delete dataset!\"");
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-10-23 18:06:24 +02:00
|
|
|
@RequestMapping(method = RequestMethod.GET, value = { "/dataset/assignDMPToDataset" })
|
2017-10-04 19:44:41 +02:00
|
|
|
public @ResponseBody ResponseEntity<Object> assignDMPToDataset(@RequestParam("datasetID") String datasetID, @RequestParam("dmpID") String dmpID) {
|
2017-10-06 19:20:05 +02:00
|
|
|
|
2017-10-04 19:44:41 +02:00
|
|
|
Dataset dataset = null;
|
|
|
|
try {
|
|
|
|
dataset = datasetDao.read(UUID.fromString(datasetID));
|
2017-10-06 19:20:05 +02:00
|
|
|
if(dataset==null || dataset.getId()==null) throw new Exception("Could not find a Dataset by this id");
|
|
|
|
DMP dmp = new DMP();
|
|
|
|
dmp.setId(UUID.fromString(dmpID));
|
2017-10-04 19:44:41 +02:00
|
|
|
dataset.setDmp(dmp);
|
|
|
|
datasetDao.update(dataset);
|
|
|
|
return ResponseEntity.status(HttpStatus.OK).build();
|
|
|
|
}
|
|
|
|
catch(Exception ex) {
|
|
|
|
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).build();
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-10-23 18:06:24 +02:00
|
|
|
@RequestMapping(method = RequestMethod.GET, value = { "/dataset/assignProfileToDataset" })
|
|
|
|
public @ResponseBody ResponseEntity<Object> assignProfileToDataset(@RequestParam("datasetID") String datasetID, @RequestParam("profileID") String profileID) {
|
|
|
|
|
|
|
|
Dataset dataset = null;
|
|
|
|
try {
|
|
|
|
dataset = datasetDao.read(UUID.fromString(datasetID));
|
|
|
|
if(dataset==null || dataset.getId()==null) throw new Exception("Could not find a Dataset by this id");
|
|
|
|
DatasetProfile profile = new DatasetProfile();
|
|
|
|
profile.setId(UUID.fromString(profileID));
|
|
|
|
dataset.setProfile(profile);
|
|
|
|
datasetDao.update(dataset);
|
|
|
|
return ResponseEntity.status(HttpStatus.OK).build();
|
|
|
|
}
|
|
|
|
catch(Exception ex) {
|
|
|
|
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).build();
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2017-11-02 15:25:05 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
2017-10-04 11:48:21 +02:00
|
|
|
}
|
|
|
|
|