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

rapture.kernel.SearchApiImplWrapper Maven / Gradle / Ivy

There is a newer version: 3.0.4
Show newest version
/**
 * The MIT License (MIT)
 *
 * Copyright (C) 2011-2016 Incapture Technologies LLC
 *
 * Permission is hereby granted, free of charge, to any person obtaining a copy
 * of this software and associated documentation files (the "Software"), to deal
 * in the Software without restriction, including without limitation the rights
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 * copies of the Software, and to permit persons to whom the Software is
 * furnished to do so, subject to the following conditions:
 *
 * The above copyright notice and this permission notice shall be included in all
 * copies or substantial portions of the Software.
 *
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
 * SOFTWARE.
 */

/**
 * This is an autogenerated file. You should not edit this file as any changes
 * will be overwritten.
 */

package rapture.kernel;

import org.apache.log4j.Logger;

import java.util.List;
import java.util.Map;

import rapture.common.api.SearchApi;
import rapture.common.CallingContext;
import rapture.common.RaptureEntitlementsContext;

import rapture.common.hooks.CallName;

import rapture.common.model.BasePayload;
import rapture.common.EntitlementSet;
import rapture.kernel.context.ContextValidator;

import rapture.common.model.SearchRepoConfig;
import rapture.common.SearchResponse;

import rapture.common.shared.search.SearchPayload;

import rapture.common.shared.search.SearchWithCursorPayload;

import rapture.common.shared.search.QualifiedSearchPayload;

import rapture.common.shared.search.QualifiedSearchWithCursorPayload;

import rapture.common.shared.search.ValidateSearchRepoPayload;

import rapture.common.shared.search.CreateSearchRepoPayload;

import rapture.common.shared.search.SearchRepoExistsPayload;

import rapture.common.shared.search.GetSearchRepoConfigPayload;

import rapture.common.shared.search.GetSearchRepoConfigsPayload;

import rapture.common.shared.search.DeleteSearchRepoPayload;

import rapture.common.shared.search.RebuildDocRepoIndexPayload;

import rapture.common.shared.search.DropDocRepoIndexPayload;


/**
 * This class is a wrapper around the class {@link SearchApiImpl}. This is an auto-generated class that gives us the ability to add hooks such as entitlmeent
 * checks before each function call in the implementation. Since we always want to call these hooks, an instance of this class should be used 
 * (in {@link Kernel}) instead of using the implementation directly.
 * implementation directly. 
 *
 */
@SuppressWarnings("all")
public class SearchApiImplWrapper implements SearchApi, KernelApi {
    private static final Logger log = Logger.getLogger(SearchApiImplWrapper.class);
    private SearchApiImpl apiImpl;

    public SearchApiImplWrapper(Kernel kernel) {
        apiImpl = new SearchApiImpl(kernel);
    }

    /**
     * Returns the underlying implementation object. This should be used when a call is deliberately bypassing entitlement checks.
     * @return {@link Search}
     */
    public SearchApiImpl getTrusted() {
        return apiImpl;
    }

    @Override
    public void start() {
        apiImpl.start();
    }

    /**
    * 
    */
    @Override
    public SearchResponse search(CallingContext context, String query) {
        long functionStartTime = System.currentTimeMillis();
       
        SearchPayload requestObj = new SearchPayload();
        requestObj.setContext(context);
        requestObj.setQuery(query);
        ContextValidator.validateContext(context, EntitlementSet.Search_search, requestObj); 
        
        long preToPostStartTime = System.currentTimeMillis();
        
        Kernel.getApiHooksService().pre(context, CallName.Search_search);
        SearchResponse returnValue = apiImpl.search(context, query);    Kernel.getApiHooksService().post(context, CallName.Search_search);
        
        long endFunctionTime = System.currentTimeMillis();
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.search.fullFunctionTime.succeeded", (endFunctionTime-functionStartTime));
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.search.preToPostTime.succeeded", (endFunctionTime-preToPostStartTime));
            
        return returnValue;}

    /**
    * 
    */
    @Override
    public SearchResponse searchWithCursor(CallingContext context, String cursorId, int size, String query) {
        long functionStartTime = System.currentTimeMillis();
       
        SearchWithCursorPayload requestObj = new SearchWithCursorPayload();
        requestObj.setContext(context);
        requestObj.setCursorId(cursorId);
        requestObj.setSize(size);
        requestObj.setQuery(query);
        ContextValidator.validateContext(context, EntitlementSet.Search_searchWithCursor, requestObj); 
        
        long preToPostStartTime = System.currentTimeMillis();
        
        Kernel.getApiHooksService().pre(context, CallName.Search_searchWithCursor);
        SearchResponse returnValue = apiImpl.searchWithCursor(context, cursorId, size, query);    Kernel.getApiHooksService().post(context, CallName.Search_searchWithCursor);
        
        long endFunctionTime = System.currentTimeMillis();
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.searchWithCursor.fullFunctionTime.succeeded", (endFunctionTime-functionStartTime));
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.searchWithCursor.preToPostTime.succeeded", (endFunctionTime-preToPostStartTime));
            
        return returnValue;}

    /**
    * 
    */
    @Override
    public SearchResponse qualifiedSearch(CallingContext context, String searchRepo, List types, String query) {
        long functionStartTime = System.currentTimeMillis();
       
        QualifiedSearchPayload requestObj = new QualifiedSearchPayload();
        requestObj.setContext(context);
        requestObj.setSearchRepo(searchRepo);
        requestObj.setTypes(types);
        requestObj.setQuery(query);
        ContextValidator.validateContext(context, EntitlementSet.Search_qualifiedSearch, requestObj); 
        
        long preToPostStartTime = System.currentTimeMillis();
        
        Kernel.getApiHooksService().pre(context, CallName.Search_qualifiedSearch);
        SearchResponse returnValue = apiImpl.qualifiedSearch(context, searchRepo, types, query);    Kernel.getApiHooksService().post(context, CallName.Search_qualifiedSearch);
        
        long endFunctionTime = System.currentTimeMillis();
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.qualifiedSearch.fullFunctionTime.succeeded", (endFunctionTime-functionStartTime));
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.qualifiedSearch.preToPostTime.succeeded", (endFunctionTime-preToPostStartTime));
            
        return returnValue;}

    /**
    * 
    */
    @Override
    public SearchResponse qualifiedSearchWithCursor(CallingContext context, String searchRepo, List types, String cursorId, int size, String query) {
        long functionStartTime = System.currentTimeMillis();
       
        QualifiedSearchWithCursorPayload requestObj = new QualifiedSearchWithCursorPayload();
        requestObj.setContext(context);
        requestObj.setSearchRepo(searchRepo);
        requestObj.setTypes(types);
        requestObj.setCursorId(cursorId);
        requestObj.setSize(size);
        requestObj.setQuery(query);
        ContextValidator.validateContext(context, EntitlementSet.Search_qualifiedSearchWithCursor, requestObj); 
        
        long preToPostStartTime = System.currentTimeMillis();
        
        Kernel.getApiHooksService().pre(context, CallName.Search_qualifiedSearchWithCursor);
        SearchResponse returnValue = apiImpl.qualifiedSearchWithCursor(context, searchRepo, types, cursorId, size, query);    Kernel.getApiHooksService().post(context, CallName.Search_qualifiedSearchWithCursor);
        
        long endFunctionTime = System.currentTimeMillis();
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.qualifiedSearchWithCursor.fullFunctionTime.succeeded", (endFunctionTime-functionStartTime));
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.qualifiedSearchWithCursor.preToPostTime.succeeded", (endFunctionTime-preToPostStartTime));
            
        return returnValue;}

    /**
    * 
    */
    @Override
    public Boolean validateSearchRepo(CallingContext context, String searchRepoUri) {
        long functionStartTime = System.currentTimeMillis();
       
        ValidateSearchRepoPayload requestObj = new ValidateSearchRepoPayload();
        requestObj.setContext(context);
        requestObj.setSearchRepoUri(searchRepoUri);
        ContextValidator.validateContext(context, EntitlementSet.Search_validateSearchRepo, requestObj); 
        
        long preToPostStartTime = System.currentTimeMillis();
        
        Kernel.getApiHooksService().pre(context, CallName.Search_validateSearchRepo);
        Boolean returnValue = apiImpl.validateSearchRepo(context, searchRepoUri);    Kernel.getApiHooksService().post(context, CallName.Search_validateSearchRepo);
        
        long endFunctionTime = System.currentTimeMillis();
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.validateSearchRepo.fullFunctionTime.succeeded", (endFunctionTime-functionStartTime));
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.validateSearchRepo.preToPostTime.succeeded", (endFunctionTime-preToPostStartTime));
            
        return returnValue;}

    /**
    * 
    */
    @Override
    public void createSearchRepo(CallingContext context, String searchRepoUri, String config) {
        long functionStartTime = System.currentTimeMillis();
       
        CreateSearchRepoPayload requestObj = new CreateSearchRepoPayload();
        requestObj.setContext(context);
        requestObj.setSearchRepoUri(searchRepoUri);
        requestObj.setConfig(config);
        ContextValidator.validateContext(context, EntitlementSet.Search_createSearchRepo, requestObj); 
        
        long preToPostStartTime = System.currentTimeMillis();
        
        Kernel.getApiHooksService().pre(context, CallName.Search_createSearchRepo);
        apiImpl.createSearchRepo(context, searchRepoUri, config);    Kernel.getApiHooksService().post(context, CallName.Search_createSearchRepo);
        
        long endFunctionTime = System.currentTimeMillis();
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.createSearchRepo.fullFunctionTime.succeeded", (endFunctionTime-functionStartTime));
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.createSearchRepo.preToPostTime.succeeded", (endFunctionTime-preToPostStartTime));
            
    }

    /**
    * 
    */
    @Override
    public Boolean searchRepoExists(CallingContext context, String searchRepoUri) {
        long functionStartTime = System.currentTimeMillis();
       
        SearchRepoExistsPayload requestObj = new SearchRepoExistsPayload();
        requestObj.setContext(context);
        requestObj.setSearchRepoUri(searchRepoUri);
        ContextValidator.validateContext(context, EntitlementSet.Search_searchRepoExists, requestObj); 
        
        long preToPostStartTime = System.currentTimeMillis();
        
        Kernel.getApiHooksService().pre(context, CallName.Search_searchRepoExists);
        Boolean returnValue = apiImpl.searchRepoExists(context, searchRepoUri);    Kernel.getApiHooksService().post(context, CallName.Search_searchRepoExists);
        
        long endFunctionTime = System.currentTimeMillis();
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.searchRepoExists.fullFunctionTime.succeeded", (endFunctionTime-functionStartTime));
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.searchRepoExists.preToPostTime.succeeded", (endFunctionTime-preToPostStartTime));
            
        return returnValue;}

    /**
    * 
    */
    @Override
    public SearchRepoConfig getSearchRepoConfig(CallingContext context, String searchRepoUri) {
        long functionStartTime = System.currentTimeMillis();
       
        GetSearchRepoConfigPayload requestObj = new GetSearchRepoConfigPayload();
        requestObj.setContext(context);
        requestObj.setSearchRepoUri(searchRepoUri);
        ContextValidator.validateContext(context, EntitlementSet.Search_getSearchRepoConfig, requestObj); 
        
        long preToPostStartTime = System.currentTimeMillis();
        
        Kernel.getApiHooksService().pre(context, CallName.Search_getSearchRepoConfig);
        SearchRepoConfig returnValue = apiImpl.getSearchRepoConfig(context, searchRepoUri);    Kernel.getApiHooksService().post(context, CallName.Search_getSearchRepoConfig);
        
        long endFunctionTime = System.currentTimeMillis();
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.getSearchRepoConfig.fullFunctionTime.succeeded", (endFunctionTime-functionStartTime));
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.getSearchRepoConfig.preToPostTime.succeeded", (endFunctionTime-preToPostStartTime));
            
        return returnValue;}

    /**
    * 
    */
    @Override
    public List getSearchRepoConfigs(CallingContext context) {
        long functionStartTime = System.currentTimeMillis();
       
        GetSearchRepoConfigsPayload requestObj = new GetSearchRepoConfigsPayload();
        requestObj.setContext(context);
        ContextValidator.validateContext(context, EntitlementSet.Search_getSearchRepoConfigs, requestObj); 
        
        long preToPostStartTime = System.currentTimeMillis();
        
        Kernel.getApiHooksService().pre(context, CallName.Search_getSearchRepoConfigs);
        List returnValue = apiImpl.getSearchRepoConfigs(context);    Kernel.getApiHooksService().post(context, CallName.Search_getSearchRepoConfigs);
        
        long endFunctionTime = System.currentTimeMillis();
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.getSearchRepoConfigs.fullFunctionTime.succeeded", (endFunctionTime-functionStartTime));
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.getSearchRepoConfigs.preToPostTime.succeeded", (endFunctionTime-preToPostStartTime));
            
        return returnValue;}

    /**
    * 
    */
    @Override
    public void deleteSearchRepo(CallingContext context, String searchRepoUri) {
        long functionStartTime = System.currentTimeMillis();
       
        DeleteSearchRepoPayload requestObj = new DeleteSearchRepoPayload();
        requestObj.setContext(context);
        requestObj.setSearchRepoUri(searchRepoUri);
        ContextValidator.validateContext(context, EntitlementSet.Search_deleteSearchRepo, requestObj); 
        
        long preToPostStartTime = System.currentTimeMillis();
        
        Kernel.getApiHooksService().pre(context, CallName.Search_deleteSearchRepo);
        apiImpl.deleteSearchRepo(context, searchRepoUri);    Kernel.getApiHooksService().post(context, CallName.Search_deleteSearchRepo);
        
        long endFunctionTime = System.currentTimeMillis();
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.deleteSearchRepo.fullFunctionTime.succeeded", (endFunctionTime-functionStartTime));
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.deleteSearchRepo.preToPostTime.succeeded", (endFunctionTime-preToPostStartTime));
            
    }

    /**
    * 
    */
    @Override
    public void rebuildDocRepoIndex(CallingContext context, String docRepoUri) {
        long functionStartTime = System.currentTimeMillis();
       
        RebuildDocRepoIndexPayload requestObj = new RebuildDocRepoIndexPayload();
        requestObj.setContext(context);
        requestObj.setDocRepoUri(docRepoUri);
        ContextValidator.validateContext(context, EntitlementSet.Search_rebuildDocRepoIndex, requestObj); 
        
        long preToPostStartTime = System.currentTimeMillis();
        
        Kernel.getApiHooksService().pre(context, CallName.Search_rebuildDocRepoIndex);
        apiImpl.rebuildDocRepoIndex(context, docRepoUri);    Kernel.getApiHooksService().post(context, CallName.Search_rebuildDocRepoIndex);
        
        long endFunctionTime = System.currentTimeMillis();
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.rebuildDocRepoIndex.fullFunctionTime.succeeded", (endFunctionTime-functionStartTime));
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.rebuildDocRepoIndex.preToPostTime.succeeded", (endFunctionTime-preToPostStartTime));
            
    }

    /**
    * 
    */
    @Override
    public void dropDocRepoIndex(CallingContext context, String docRepoUri) {
        long functionStartTime = System.currentTimeMillis();
       
        DropDocRepoIndexPayload requestObj = new DropDocRepoIndexPayload();
        requestObj.setContext(context);
        requestObj.setDocRepoUri(docRepoUri);
        ContextValidator.validateContext(context, EntitlementSet.Search_dropDocRepoIndex, requestObj); 
        
        long preToPostStartTime = System.currentTimeMillis();
        
        Kernel.getApiHooksService().pre(context, CallName.Search_dropDocRepoIndex);
        apiImpl.dropDocRepoIndex(context, docRepoUri);    Kernel.getApiHooksService().post(context, CallName.Search_dropDocRepoIndex);
        
        long endFunctionTime = System.currentTimeMillis();
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.dropDocRepoIndex.fullFunctionTime.succeeded", (endFunctionTime-functionStartTime));
        Kernel.getMetricsService().recordTimeDifference("apiMetrics.searchApi.dropDocRepoIndex.preToPostTime.succeeded", (endFunctionTime-preToPostStartTime));
            
    }

}





© 2015 - 2025 Weber Informatics LLC | Privacy Policy