argos/dmp-backend/elastic/src/main/java/eu/eudat/elastic/repository/ElasticRepository.java

49 lines
1.5 KiB
Java
Raw Normal View History

2018-07-11 15:47:36 +02:00
package eu.eudat.elastic.repository;
import com.fasterxml.jackson.databind.ObjectMapper;
import eu.eudat.elastic.criteria.Criteria;
import eu.eudat.elastic.entities.ElasticEntity;
import org.elasticsearch.client.Client;
2020-04-06 17:34:25 +02:00
import org.elasticsearch.client.RequestOptions;
2018-07-11 15:47:36 +02:00
import org.elasticsearch.client.RestClient;
import org.elasticsearch.client.RestHighLevelClient;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
2018-07-11 15:47:36 +02:00
import java.io.IOException;
/**
* Created by ikalyvas on 7/5/2018.
*/
public abstract class ElasticRepository<T extends ElasticEntity,C extends Criteria> implements Repository<T,C> {
private static final Logger logger = LoggerFactory.getLogger(ElasticRepository.class);
2022-04-29 12:32:22 +02:00
private final ObjectMapper mapper;
2018-07-11 15:47:36 +02:00
private RestHighLevelClient client;
public RestHighLevelClient getClient() {
return client;
}
public ElasticRepository(RestHighLevelClient client) {
2020-04-06 17:34:25 +02:00
try {
if (client.ping(RequestOptions.DEFAULT)) {
this.client = client;
}
} catch (IOException e) {
logger.warn("Unable to connect to Elastic Services");
this.client = null;
}
2022-04-29 12:32:22 +02:00
this.mapper = new ObjectMapper();
2018-07-11 15:47:36 +02:00
}
public <T> T transformFromString(String value, Class<T> tClass) {
T item = null;
try {
item = mapper.readValue(value, tClass);
} catch (IOException e) {
logger.error(e.getMessage(), e);
2018-07-11 15:47:36 +02:00
}
return item;
}
}