| package de.ids_mannheim.korap; |
| |
| import java.util.*; |
| import de.ids_mannheim.korap.KorapMatch; |
| import de.ids_mannheim.korap.index.PositionsToOffset; |
| |
| import org.slf4j.Logger; |
| import org.slf4j.LoggerFactory; |
| |
| import com.fasterxml.jackson.databind.ObjectMapper; |
| import com.fasterxml.jackson.databind.SerializationFeature; |
| import com.fasterxml.jackson.databind.JsonNode; |
| import com.fasterxml.jackson.databind.node.*; |
| import com.fasterxml.jackson.annotation.*; |
| |
| /* |
| TODO: Reuse the KorapSearch code for data serialization! |
| */ |
| |
| public class KorapResult { |
| ObjectMapper mapper = new ObjectMapper(); |
| |
| public static final short ITEMS_PER_PAGE = 25; |
| private String query; |
| |
| private List<KorapMatch> matches; |
| |
| private int totalResults = 0; |
| private int startIndex = 0; |
| |
| private short itemsPerPage = ITEMS_PER_PAGE; |
| private short leftContextOffset = 6, |
| rightContextOffset = 6; |
| private boolean leftTokenContext, |
| rightTokenContext; |
| |
| private String benchmarkSearchResults, |
| benchmarkHitCounter; |
| private String error = null; |
| private String version; |
| |
| private JsonNode request; |
| |
| // Logger |
| // This is KorapMatch instead of KorapResult! |
| private final static Logger log = LoggerFactory.getLogger(KorapMatch.class); |
| |
| // Empty result |
| public KorapResult () { |
| }; |
| |
| public KorapResult (String query, |
| int startIndex, |
| short itemsPerPage, |
| boolean leftTokenContext, |
| short leftContextOffset, |
| boolean rightTokenContext, |
| short rightContextOffset) { |
| |
| mapper.enable(SerializationFeature.INDENT_OUTPUT); |
| // mapper.disable(SerializationFeature.FAIL_ON_EMPTY_BEANS); |
| mapper.disable(SerializationFeature.WRITE_NULL_MAP_VALUES); |
| |
| this.matches = new ArrayList<>(itemsPerPage); |
| this.query = query; |
| this.startIndex = startIndex; |
| this.itemsPerPage = (itemsPerPage > 50 || itemsPerPage < 1) ? ITEMS_PER_PAGE : itemsPerPage; |
| this.leftContextOffset = leftContextOffset; |
| this.rightContextOffset = rightContextOffset; |
| |
| this.leftTokenContext = leftTokenContext; |
| this.rightTokenContext = rightTokenContext; |
| }; |
| |
| public void add (KorapMatch km) { |
| this.matches.add(km); |
| }; |
| |
| public KorapMatch addMatch (PositionsToOffset pto, int localDocID, int startPos, int endPos) { |
| KorapMatch km = new KorapMatch(pto, localDocID, startPos, endPos); |
| |
| // Temporary - should use the same interface like results |
| // in the future: |
| km.leftContextOffset = this.leftContextOffset; |
| km.leftTokenContext = this.leftTokenContext; |
| km.rightContextOffset = this.rightContextOffset; |
| km.rightTokenContext = this.rightTokenContext; |
| |
| // Add pos for context |
| // That's not really a good position for it, |
| // to be honest ... |
| // But maybe it will make the offset |
| // information in the match be obsolete! |
| if (km.leftTokenContext) { |
| pto.add(localDocID, startPos - this.leftContextOffset); |
| }; |
| if (km.rightTokenContext) { |
| pto.add(localDocID, endPos + this.rightContextOffset - 1); |
| }; |
| |
| this.add(km); |
| return km; |
| }; |
| |
| public void setTotalResults (int i) { |
| this.totalResults = i; |
| }; |
| |
| public int getTotalResults () { |
| return this.totalResults; |
| }; |
| |
| |
| @Deprecated |
| public int totalResults () { |
| return this.totalResults; |
| }; |
| |
| @JsonIgnore |
| public void setVersion (String version) { |
| this.version = version; |
| }; |
| |
| @JsonIgnore |
| public String getVersion () { |
| if (this.version == null) |
| return null; |
| return "lucene-backend-" + this.version; |
| }; |
| |
| public short getItemsPerPage () { |
| return this.itemsPerPage; |
| }; |
| |
| @Deprecated |
| public short itemsPerPage () { |
| return this.itemsPerPage; |
| }; |
| |
| public String getError () { |
| return this.error; |
| }; |
| |
| public void setError (String msg) { |
| this.error = msg; |
| }; |
| |
| public void setRequest (JsonNode request) { |
| this.request = request; |
| }; |
| |
| public JsonNode getRequest () { |
| return this.request; |
| }; |
| |
| public void setBenchmarkSearchResults (long t1, long t2) { |
| this.benchmarkSearchResults = |
| (t2 - t1) < 100_000_000 ? (((double)(t2 - t1) * 1e-6) + " ms") : |
| (((double)(t2 - t1) / 1000000000.0) + " s"); |
| }; |
| |
| public String getBenchmarkSearchResults () { |
| return this.benchmarkSearchResults; |
| }; |
| |
| public void setBenchmarkHitCounter (long t1, long t2) { |
| this.benchmarkHitCounter = |
| (t2 - t1) < 100_000_000 ? (((double)(t2 - t1) * 1e-6) + " ms") : |
| (((double)(t2 - t1) / 1000000000.0) + " s"); |
| }; |
| |
| public String getBenchmarkHitCounter () { |
| return this.benchmarkHitCounter; |
| }; |
| |
| public String getQuery () { |
| return this.query; |
| }; |
| |
| public KorapMatch getMatch (int index) { |
| return this.matches.get(index); |
| }; |
| |
| public List<KorapMatch> getMatches () { |
| return this.matches; |
| }; |
| |
| @Deprecated |
| public KorapMatch match (int index) { |
| return this.matches.get(index); |
| }; |
| |
| public int getStartIndex () { |
| return startIndex; |
| }; |
| |
| // Identical to KorapMatch! |
| public String toJSON () { |
| ObjectNode json = (ObjectNode) mapper.valueToTree(this); |
| |
| ArrayNode leftContext = mapper.createArrayNode(); |
| leftContext.add(this.leftTokenContext ? "token" : "char"); |
| leftContext.add(this.leftContextOffset); |
| |
| ArrayNode rightContext = mapper.createArrayNode(); |
| rightContext.add(this.rightTokenContext ? "token" : "char"); |
| rightContext.add(this.rightContextOffset); |
| |
| ObjectNode context = mapper.createObjectNode(); |
| context.put("left", leftContext); |
| context.put("right", rightContext); |
| json.put("context", context); |
| |
| if (this.version != null) |
| json.put("version", this.version); |
| |
| try { |
| return mapper.writeValueAsString(json); |
| } |
| catch (Exception e) { |
| log.warn(e.getLocalizedMessage()); |
| }; |
| |
| return "{}"; |
| }; |
| }; |