2017-10-12 14:04:38 +02:00
|
|
|
package rest.entities;
|
2017-10-04 11:48:21 +02:00
|
|
|
|
2017-10-18 01:26:27 +02:00
|
|
|
import java.io.IOException;
|
|
|
|
import java.io.PrintStream;
|
2017-10-04 11:48:21 +02:00
|
|
|
import java.util.List;
|
|
|
|
import java.util.UUID;
|
|
|
|
|
2017-10-18 01:26:27 +02:00
|
|
|
import javax.transaction.Transactional;
|
|
|
|
|
2017-10-04 11:48:21 +02:00
|
|
|
import org.apache.commons.lang3.SerializationUtils;
|
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
import org.springframework.http.HttpStatus;
|
|
|
|
import org.springframework.http.MediaType;
|
|
|
|
import org.springframework.http.ResponseEntity;
|
|
|
|
import org.springframework.util.MultiValueMap;
|
|
|
|
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;
|
|
|
|
|
2017-10-18 01:26:27 +02:00
|
|
|
import com.fasterxml.jackson.core.JsonParseException;
|
2017-10-04 11:48:21 +02:00
|
|
|
import com.fasterxml.jackson.core.JsonProcessingException;
|
2017-10-18 01:26:27 +02:00
|
|
|
import com.fasterxml.jackson.databind.JsonMappingException;
|
2017-10-04 11:48:21 +02:00
|
|
|
import com.fasterxml.jackson.databind.ObjectMapper;
|
|
|
|
|
|
|
|
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;
|
|
|
|
import entities.DMP;
|
2017-10-18 01:26:27 +02:00
|
|
|
import entities.DMPProfile;
|
2017-10-04 11:48:21 +02:00
|
|
|
import entities.Dataset;
|
|
|
|
import entities.DatasetProfile;
|
|
|
|
import entities.DatasetProfileRuleset;
|
2017-10-18 01:26:27 +02:00
|
|
|
import entities.DatasetProfileViewstyle;
|
2017-10-04 11:48:21 +02:00
|
|
|
import entities.Project;
|
|
|
|
import helpers.Transformers;
|
|
|
|
import responses.RestResponse;
|
|
|
|
|
|
|
|
|
|
|
|
@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-10-18 01:26:27 +02:00
|
|
|
private ObjectMapper objectMapper = new ObjectMapper();
|
2017-10-04 11:48:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
// FETCH BY DATASET(S)
|
|
|
|
|
|
|
|
@RequestMapping(method = RequestMethod.GET, value = { "/dataset" })
|
|
|
|
public @ResponseBody ResponseEntity<Object> listDatasets(){
|
|
|
|
try {
|
|
|
|
List<UUID> allIDs = datasetDao.listAllIDs();
|
|
|
|
return ResponseEntity.status(HttpStatus.OK).body(new ObjectMapper().writeValueAsString(allIDs));
|
|
|
|
}
|
|
|
|
catch(Exception ex) {
|
|
|
|
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("Serialization issue: "+ex.getMessage());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@RequestMapping(method = RequestMethod.GET, value = { "/dataset/{id}" })
|
|
|
|
public @ResponseBody ResponseEntity<Object> getDataset(@PathVariable("id") String id) {
|
|
|
|
try {
|
|
|
|
Dataset ds = datasetDao.read(UUID.fromString(id));
|
|
|
|
return ResponseEntity.status(HttpStatus.OK).body(new ObjectMapper().writeValueAsString(ds));
|
|
|
|
}
|
|
|
|
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
|
|
|
|
*/
|
|
|
|
@RequestMapping(method = RequestMethod.GET, value = { "/getAllDatasets" })
|
|
|
|
public @ResponseBody ResponseEntity<Object> getAllDatasets(){
|
|
|
|
try {
|
|
|
|
List<Dataset> allDatasets = datasetDao.getAll();
|
|
|
|
return ResponseEntity.status(HttpStatus.OK).body(new ObjectMapper().writeValueAsString(allDatasets));
|
|
|
|
}
|
|
|
|
catch(Exception ex) {
|
|
|
|
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("Serialization issue: "+ex.getMessage());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
@RequestMapping(method = RequestMethod.POST, value = { "/setDataset" }, consumes = "application/json")
|
|
|
|
public @ResponseBody ResponseEntity<Object> setDataset(@RequestBody Dataset dataset) {
|
|
|
|
|
|
|
|
String reason = "";
|
|
|
|
Dataset storedDataset = null;
|
|
|
|
//try first to create
|
|
|
|
try {
|
|
|
|
storedDataset = datasetDao.create(dataset);
|
|
|
|
RestResponse rr = new RestResponse("Created dataset with id: "+storedDataset.toString(), storedDataset.getId().toString());
|
|
|
|
return ResponseEntity.status(HttpStatus.CREATED).body(rr.toString());
|
|
|
|
}
|
|
|
|
catch(Exception e) {
|
|
|
|
e.printStackTrace();
|
|
|
|
reason += e.getMessage();
|
|
|
|
//try updating
|
|
|
|
try {
|
|
|
|
storedDataset = datasetDao.update(dataset);
|
|
|
|
RestResponse rr = new RestResponse("Updated dataset with id: "+storedDataset.toString(), storedDataset.getId().toString());
|
|
|
|
return ResponseEntity.status(HttpStatus.CREATED).body(rr.toString());
|
|
|
|
}
|
|
|
|
catch(Exception ex) {
|
|
|
|
ex.printStackTrace();
|
|
|
|
reason += (System.lineSeparator()+e.getMessage());
|
|
|
|
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("Could not create or update Dataset! Reason: " + reason);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2017-10-06 19:20:05 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2017-10-04 11:48:21 +02:00
|
|
|
@RequestMapping(method = RequestMethod.POST, value = { "/deleteDataset" }, consumes = "application/json")
|
|
|
|
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-10-04 19:44:41 +02:00
|
|
|
@RequestMapping(method = RequestMethod.GET, value = { "/assignDMPToDataset" })
|
|
|
|
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-04 11:48:21 +02:00
|
|
|
/*
|
|
|
|
@RequestMapping(method = RequestMethod.GET, value = { "/createEmptyDataset" })
|
|
|
|
public @ResponseBody ResponseEntity<Object> createEmptyDataset() {
|
|
|
|
Dataset dataset = new Dataset();
|
|
|
|
dataset.setLabel("");
|
|
|
|
|
|
|
|
try {
|
|
|
|
dataset = datasetDao.create(dataset);
|
|
|
|
}
|
|
|
|
catch(Exception e) {
|
|
|
|
e.printStackTrace();
|
|
|
|
try {
|
|
|
|
dataset = datasetDao.update(dataset);
|
|
|
|
}
|
|
|
|
catch(Exception ex) {
|
|
|
|
ex.printStackTrace();
|
|
|
|
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("FAILED: reason: "+e.getMessage());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return ResponseEntity.status(HttpStatus.CREATED).body("Created Dataset with id: " + dataset.getId());
|
|
|
|
}
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
//FETCH BY DATASET PROFILE
|
|
|
|
|
|
|
|
@RequestMapping(method = RequestMethod.GET, value = { "/datasetprofile/{id}" })
|
|
|
|
public @ResponseBody ResponseEntity<Object> getDatasetProfile(@PathVariable("id") String id) {
|
|
|
|
try {
|
|
|
|
DatasetProfile profile = datasetProfileDao.read(UUID.fromString(id));
|
|
|
|
return ResponseEntity.status(HttpStatus.OK).body(new ObjectMapper().writeValueAsString(profile));
|
|
|
|
}
|
|
|
|
catch(Exception ex) {
|
|
|
|
return ResponseEntity.status(HttpStatus.BAD_REQUEST).body("Erroneous input: "+ex.getMessage());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-10-18 01:26:27 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//@Transactional
|
|
|
|
@RequestMapping(method = RequestMethod.POST, value = { "/datasetprofile/set" }, consumes = "application/json", produces="application/json")
|
2017-10-04 11:48:21 +02:00
|
|
|
public @ResponseBody ResponseEntity<Object> setDatasetProfile(@RequestBody DatasetProfile datasetProfile) {
|
|
|
|
|
2017-10-18 01:26:27 +02:00
|
|
|
System.out.println("inside setDatasetProfile");
|
2017-10-04 11:48:21 +02:00
|
|
|
try {
|
2017-10-18 01:26:27 +02:00
|
|
|
System.out.println(objectMapper.writeValueAsString(datasetProfile));
|
|
|
|
} catch (JsonProcessingException e) {
|
|
|
|
e.printStackTrace();
|
2017-10-04 11:48:21 +02:00
|
|
|
}
|
2017-10-18 01:26:27 +02:00
|
|
|
|
|
|
|
if(datasetProfile.getRuleset()!=null && datasetProfile.getRuleset().getId()!=null){
|
|
|
|
DatasetProfileRuleset dpr = datasetProfile.getRuleset();
|
|
|
|
datasetProfileRulesetDao.update(dpr);
|
|
|
|
DatasetProfileRuleset n = new DatasetProfileRuleset();
|
|
|
|
n.setId(dpr.getId());
|
|
|
|
datasetProfile.setRuleset(n);
|
|
|
|
}
|
|
|
|
|
|
|
|
if(datasetProfile.getViewstyle()!=null && datasetProfile.getViewstyle().getId()!=null){
|
|
|
|
DatasetProfileViewstyle dpv = datasetProfile.getViewstyle();
|
|
|
|
datasetProfileViewstyleDao.update(dpv);
|
|
|
|
DatasetProfileViewstyle n = new DatasetProfileViewstyle();
|
|
|
|
n.setId(dpv.getId());
|
|
|
|
datasetProfile.setViewstyle(n);
|
|
|
|
}
|
|
|
|
|
|
|
|
datasetProfile.setDataset(null);
|
|
|
|
|
|
|
|
DatasetProfile createdDatasetProfile = datasetProfileDao.update(datasetProfile);
|
|
|
|
try {
|
|
|
|
return ResponseEntity.status(HttpStatus.CREATED).body(objectMapper.writeValueAsString(createdDatasetProfile));
|
|
|
|
} catch (JsonProcessingException e) {
|
2017-10-18 15:12:25 +02:00
|
|
|
e.printStackTrace();
|
2017-10-18 01:26:27 +02:00
|
|
|
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("{\"msg\":\"Could not set dataset profile!\"}");
|
2017-10-04 11:48:21 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2017-10-18 01:26:27 +02:00
|
|
|
|
|
|
|
|
|
|
|
@RequestMapping(method = RequestMethod.POST, value = { "/createEmptyDatasetProfile" })
|
|
|
|
public @ResponseBody ResponseEntity<Object> createEmptyDatasetProfile(@RequestParam("datasetID") String datasetID) {
|
|
|
|
|
|
|
|
DatasetProfileRuleset dpr = new DatasetProfileRuleset();
|
|
|
|
dpr.setLabel("");
|
|
|
|
dpr.setDefinition("");
|
|
|
|
dpr.setId(datasetProfileRulesetDao.create(dpr).getId());
|
|
|
|
|
|
|
|
DatasetProfileViewstyle dpv = new DatasetProfileViewstyle();
|
|
|
|
dpv.setLabel("");
|
|
|
|
dpv.setDefinition("");
|
|
|
|
dpv.setId(datasetProfileViewstyleDao.create(dpv).getId());
|
|
|
|
|
2017-10-04 11:48:21 +02:00
|
|
|
DatasetProfile datasetProfile = new DatasetProfile();
|
|
|
|
datasetProfile.setLabel("");
|
|
|
|
datasetProfile.setDefinition("");
|
2017-10-18 01:26:27 +02:00
|
|
|
datasetProfile.setRuleset(dpr);
|
|
|
|
datasetProfile.setViewstyle(dpv);
|
|
|
|
|
|
|
|
Dataset ds = new Dataset();
|
|
|
|
ds.setId(UUID.fromString(datasetID));
|
|
|
|
datasetProfile.setDataset(ds);
|
|
|
|
|
2017-10-04 11:48:21 +02:00
|
|
|
try {
|
|
|
|
datasetProfile = datasetProfileDao.create(datasetProfile);
|
2017-10-06 19:20:05 +02:00
|
|
|
return ResponseEntity.status(HttpStatus.CREATED).body(new ObjectMapper().writeValueAsString(datasetProfile));
|
2017-10-04 11:48:21 +02:00
|
|
|
}
|
|
|
|
catch(Exception e) {
|
|
|
|
return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("FAILED: reason: "+e.getMessage());
|
|
|
|
}
|
|
|
|
}
|
2017-10-18 01:26:27 +02:00
|
|
|
|
2017-10-04 11:48:21 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|