All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.rbmhtechnology.vind.monitoring.logger.entry.SuggestionEntry Maven / Gradle / Ivy

There is a newer version: 3.2.0
Show newest version
/*
 * Copyright (c) 2017 Redlink GmbH.
 */
package com.rbmhtechnology.vind.monitoring.logger.entry;

import com.rbmhtechnology.vind.api.SearchServer;
import com.rbmhtechnology.vind.api.query.suggestion.ExecutableSuggestionSearch;
import com.rbmhtechnology.vind.api.result.SuggestionResult;
import com.rbmhtechnology.vind.model.DocumentFactory;
import com.rbmhtechnology.vind.monitoring.model.application.Application;
import com.rbmhtechnology.vind.monitoring.model.request.SearchRequest;
import com.rbmhtechnology.vind.monitoring.model.request.SuggestionRequest;
import com.rbmhtechnology.vind.monitoring.model.response.Response;
import com.rbmhtechnology.vind.monitoring.model.session.Session;

import java.time.ZonedDateTime;
import java.time.temporal.ChronoUnit;

/**
 * Created on 03.10.17.
 */
public class SuggestionEntry extends MonitoringEntry {

    final private EntryType type = EntryType.suggestion;
    private Application application;
    private Session session;
    private ZonedDateTime timeStamp;
    private SuggestionRequest request;
    private Response response;

    public SuggestionEntry() {
    }

    public SuggestionEntry(SearchServer server, DocumentFactory factory,
           Application application, ExecutableSuggestionSearch search, SuggestionResult result, ZonedDateTime start,
           ZonedDateTime end, long queryTime, Session session) {
        this.application = application;
        this.session = session;
        this.timeStamp = start;
        //TODO add copy to suggestion search
        this.request = new SuggestionRequest(search/*.copy()*/,server.getRawQuery(search, factory));
        this.response = new Response(result.size(), queryTime, start.until(end, ChronoUnit.MILLIS), result.getSuggestedFields().size());
    }

    public SuggestionEntry(SearchServer server, DocumentFactory factory,
                           Application application, ExecutableSuggestionSearch search, SuggestionResult result, ZonedDateTime start,
                           ZonedDateTime end, long queryTime, long elpasedTime, Session session) {
        this.application = application;
        this.session = session;
        this.timeStamp = start;
        //TODO add copy to suggestion search
        this.request = new SuggestionRequest(search/*.copy()*/,server.getRawQuery(search, factory));
        this.response = new Response(result.size(), queryTime, start.until(end, ChronoUnit.MILLIS), result.getSuggestedFields().size());
        this.response.setElapsedTime(elpasedTime);
    }

    @Override
    public Application getApplication() {
        return application;
    }

    @Override
    public Session getSession() {
        return session;
    }

    @Override
    public EntryType getType() {
        return type;
    }

    @Override
    public ZonedDateTime getTimeStamp() {
        return timeStamp;
    }

    public SearchRequest getRequest() {
        return request;
    }

    public Response getResponse() {
        return response;
    }
    
    @Override
    public String toString() {
        return toJson();
    }
}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy