argos/dmp-backend/web/src/main/java/eu/eudat/managers/DatasetProfileManager.java

81 lines
4.7 KiB
Java
Raw Normal View History

2017-12-21 10:26:11 +01:00
package eu.eudat.managers;
2018-05-14 08:44:35 +02:00
import com.jayway.jsonpath.DocumentContext;
import com.jayway.jsonpath.JsonPath;
2018-02-16 08:45:18 +01:00
import eu.eudat.builders.model.models.DataTableDataBuilder;
2018-03-21 11:57:56 +01:00
import eu.eudat.data.dao.entities.DatasetProfileDao;
import eu.eudat.data.entities.DatasetProfile;
2018-03-21 13:11:02 +01:00
import eu.eudat.data.query.items.item.datasetprofile.DatasetProfileAutocompleteRequest;
import eu.eudat.data.query.items.table.datasetprofile.DatasetProfileTableRequestItem;
2018-05-14 08:44:35 +02:00
import eu.eudat.models.components.commons.datafield.AutoCompleteData;
import eu.eudat.models.datasetprofile.DatasetProfileAutocompleteItem;
import eu.eudat.models.datasetprofile.DatasetProfileListingModel;
import eu.eudat.models.entities.xmlmodels.datasetprofiledefinition.Field;
import eu.eudat.models.helpermodels.Tuple;
2018-01-25 16:24:21 +01:00
import eu.eudat.models.helpers.common.DataTableData;
2017-12-21 10:26:11 +01:00
import eu.eudat.queryable.QueryableList;
2018-02-16 08:45:18 +01:00
import eu.eudat.services.ApiContext;
2018-03-08 11:54:56 +01:00
import eu.eudat.utilities.builders.XmlBuilder;
2018-05-14 08:44:35 +02:00
import org.springframework.http.*;
import org.springframework.web.client.RestTemplate;
2018-03-08 11:54:56 +01:00
import org.w3c.dom.Document;
import org.w3c.dom.Element;
2017-12-21 10:26:11 +01:00
2018-03-08 11:54:56 +01:00
import javax.xml.xpath.*;
2018-05-14 08:44:35 +02:00
import java.util.Collections;
import java.util.LinkedList;
2017-12-21 10:26:11 +01:00
import java.util.List;
2018-05-14 08:44:35 +02:00
import java.util.Map;
2017-12-21 10:26:11 +01:00
2018-02-01 10:08:06 +01:00
2017-12-21 10:26:11 +01:00
public class DatasetProfileManager {
2018-02-16 08:45:18 +01:00
public static List<DatasetProfileAutocompleteItem> getWithCriteria(DatasetProfileDao datasetProfileRepository, DatasetProfileAutocompleteRequest datasetProfileAutocompleteRequest) throws IllegalAccessException, InstantiationException {
2017-12-21 10:26:11 +01:00
QueryableList<DatasetProfile> items = datasetProfileRepository.getWithCriteria(datasetProfileAutocompleteRequest.getCriteria());
2018-02-21 11:07:31 +01:00
List<DatasetProfileAutocompleteItem> datasetProfiles = items.select(item -> new DatasetProfileAutocompleteItem().fromDataModel(item));
2017-12-21 10:26:11 +01:00
return datasetProfiles;
}
2018-01-03 11:44:54 +01:00
2018-02-16 08:45:18 +01:00
public static DataTableData<DatasetProfileListingModel> getPaged(ApiContext apiContext, DatasetProfileTableRequestItem datasetProfileTableRequestItem) throws Exception {
2018-03-05 17:18:45 +01:00
QueryableList<DatasetProfile> items = apiContext.getOperationsContext().getDatabaseRepository().getDatasetProfileDao().getWithCriteria(datasetProfileTableRequestItem.getCriteria());
2018-02-16 08:45:18 +01:00
QueryableList<DatasetProfile> pagedItems = PaginationManager.applyPaging(items, datasetProfileTableRequestItem);
2018-02-21 11:07:31 +01:00
List<DatasetProfileListingModel> datasetProfiles = pagedItems.select(item -> new DatasetProfileListingModel().fromDataModel(item));
2018-03-05 17:18:45 +01:00
return apiContext.getOperationsContext().getBuilderFactory().getBuilder(DataTableDataBuilder.class).data(datasetProfiles).totalCount(items.count()).build();
2018-01-03 11:44:54 +01:00
}
2018-02-16 08:45:18 +01:00
public static List<DatasetProfileListingModel> getAll(DatasetProfileDao datasetProfileRepository) throws IllegalAccessException, InstantiationException {
2018-01-03 11:44:54 +01:00
QueryableList<DatasetProfile> items = datasetProfileRepository.getAll();
2018-02-21 11:07:31 +01:00
List<DatasetProfileListingModel> datasetProfiles = items.select(item -> new DatasetProfileListingModel().fromDataModel(item));
2018-01-03 11:44:54 +01:00
return datasetProfiles;
}
2018-03-08 11:54:56 +01:00
2018-03-21 11:57:56 +01:00
public static eu.eudat.models.entities.xmlmodels.datasetprofiledefinition.Field queryForField(String xml, String fieldId) throws XPathExpressionException {
eu.eudat.models.entities.xmlmodels.datasetprofiledefinition.Field field = new Field();
2018-03-08 11:54:56 +01:00
Document document = XmlBuilder.fromXml(xml);
XPathFactory xpathFactory = XPathFactory.newInstance();
XPath xpath = xpathFactory.newXPath();
XPathExpression expr =
xpath.compile("//field[@id='" + fieldId + "']");
Element name = (Element) expr.evaluate(document, XPathConstants.NODE);
field.fromXml(name);
return field;
}
2018-05-14 08:44:35 +02:00
public static List<Tuple<String, String>> getAutocomplete(AutoCompleteData data, String like) {
List<Tuple<String, String>> result = new LinkedList<>();
RestTemplate restTemplate = new RestTemplate();
HttpHeaders headers = new HttpHeaders();
headers.setAccept(Collections.singletonList(MediaType.valueOf("application/vnd.api+json; charset=utf-8")));
headers.setContentType(MediaType.APPLICATION_JSON);
HttpEntity<String> entity = new HttpEntity<>("parameters", headers);
ResponseEntity<Object> response = restTemplate.exchange(data.getUrl() + "?search=" + like, HttpMethod.GET, entity, Object.class);
DocumentContext jsonContext = JsonPath.parse(response.getBody());
List<Map<String, String>> jsonItems = jsonContext.read(data.getOptionsRoot() + "['" + data.getAutoCompleteOptions().getLabel() + "','" + data.getAutoCompleteOptions().getValue() + "']");
jsonItems.forEach(item -> result.add(new Tuple<>(item.get(data.getAutoCompleteOptions().getValue()), item.get(data.getAutoCompleteOptions().getLabel()))));
return result;
}
2017-12-21 10:26:11 +01:00
}