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

com.hp.autonomy.hod.client.api.textindex.document.AddToTextIndexPollingService Maven / Gradle / Ivy

There is a newer version: 0.25.3
Show newest version
/*
 * Copyright 2015-2016 Hewlett-Packard Development Company, L.P.
 * Licensed under the MIT License (the "License"); you may not use this file except in compliance with the License.
 */

package com.hp.autonomy.hod.client.api.textindex.document;

import com.hp.autonomy.hod.client.api.authentication.AuthenticationToken;
import com.hp.autonomy.hod.client.api.authentication.EntityType;
import com.hp.autonomy.hod.client.api.authentication.TokenType;
import com.hp.autonomy.hod.client.api.resource.ResourceIdentifier;
import com.hp.autonomy.hod.client.config.HodServiceConfig;
import com.hp.autonomy.hod.client.config.Requester;
import com.hp.autonomy.hod.client.error.HodErrorException;
import com.hp.autonomy.hod.client.job.AbstractPollingService;
import com.hp.autonomy.hod.client.job.HodJobCallback;
import com.hp.autonomy.hod.client.job.JobId;
import com.hp.autonomy.hod.client.job.JobService;
import com.hp.autonomy.hod.client.job.JobServiceImpl;
import com.hp.autonomy.hod.client.job.JobStatus;
import com.hp.autonomy.hod.client.job.PollingJobStatusRunnable;
import com.hp.autonomy.hod.client.token.TokenProxy;
import com.hp.autonomy.hod.client.util.TypedByteArrayWithFilename;
import lombok.extern.slf4j.Slf4j;
import org.apache.commons.io.IOUtils;
import retrofit.client.Response;
import retrofit.mime.TypedFile;

import java.io.File;
import java.io.IOException;
import java.io.InputStream;
import java.util.concurrent.ScheduledExecutorService;

/**
 * Implementation of AddToTextIndexService which polls for job completion.
 * 

* The destroy method should be called when the service is no longer needed. */ @Slf4j public class AddToTextIndexPollingService extends AbstractPollingService implements AddToTextIndexService { private final AddToTextIndexBackend addToTextIndexBackend; private final JobService> jobService; private final Requester requester; /** * Creates a new AddToTextIndexPollingService with a default ScheduledExecutorService * @param hodServiceConfig The configuration for the service */ public AddToTextIndexPollingService(final HodServiceConfig hodServiceConfig) { super(hodServiceConfig.getAsyncTimeout()); addToTextIndexBackend = hodServiceConfig.getRestAdapter().create(AddToTextIndexBackend.class); jobService = new JobServiceImpl<>(hodServiceConfig, AddToTextIndexBackend.AddToTextIndexJobStatus.class); requester = hodServiceConfig.getRequester(); } /** * Creates a new AddToTextIndexPollingService * @param hodServiceConfig The configuration for the service * @param executorService The executor service to use while polling for status updates */ public AddToTextIndexPollingService(final HodServiceConfig hodServiceConfig, final ScheduledExecutorService executorService) { super(executorService, hodServiceConfig.getAsyncTimeout()); addToTextIndexBackend = hodServiceConfig.getRestAdapter().create(AddToTextIndexBackend.class); jobService = new JobServiceImpl<>(hodServiceConfig, AddToTextIndexBackend.AddToTextIndexJobStatus.class); requester = hodServiceConfig.getRequester(); } @Override public void addJsonToTextIndex( final Documents documents, final ResourceIdentifier index, final AddToTextIndexRequestBuilder params, final HodJobCallback callback ) throws HodErrorException { final JobId jobId = requester.makeRequest(JobId.class, getTextBackendCaller(documents, index, params)); getExecutorService().submit(new PollingJobStatusRunnable<>(getTimeout(), jobId, callback, getExecutorService(), jobService)); } @Override public void addJsonToTextIndex( final TokenProxy tokenProxy, final Documents documents, final ResourceIdentifier index, final AddToTextIndexRequestBuilder params, final HodJobCallback callback ) throws HodErrorException { final JobId jobId = requester.makeRequest(tokenProxy, JobId.class, getTextBackendCaller(documents, index, params)); getExecutorService().submit(new PollingJobStatusRunnable<>(tokenProxy, getTimeout(), jobId, callback, getExecutorService(), jobService)); } @Override public void addUrlToTextIndex( final String url, final ResourceIdentifier index, final AddToTextIndexRequestBuilder params, final HodJobCallback callback ) throws HodErrorException { final JobId jobId = requester.makeRequest(JobId.class, getUrlBackendCaller(url, index, params)); getExecutorService().submit(new PollingJobStatusRunnable<>(getTimeout(), jobId, callback, getExecutorService(), jobService)); } @Override public void addUrlToTextIndex( final TokenProxy tokenProxy, final String url, final ResourceIdentifier index, final AddToTextIndexRequestBuilder params, final HodJobCallback callback ) throws HodErrorException { final JobId jobId = requester.makeRequest(tokenProxy, JobId.class, getUrlBackendCaller(url, index, params)); getExecutorService().submit(new PollingJobStatusRunnable<>(tokenProxy, getTimeout(), jobId, callback, getExecutorService(), jobService)); } @Override public void addReferenceToTextIndex( final String reference, final ResourceIdentifier index, final AddToTextIndexRequestBuilder params, final HodJobCallback callback ) throws HodErrorException { final JobId jobId = requester.makeRequest(JobId.class, getReferenceBackendCaller(reference, index, params)); getExecutorService().submit(new PollingJobStatusRunnable<>(getTimeout(), jobId, callback, getExecutorService(), jobService)); } @Override public void addReferenceToTextIndex( final TokenProxy tokenProxy, final String reference, final ResourceIdentifier index, final AddToTextIndexRequestBuilder params, final HodJobCallback callback ) throws HodErrorException { final JobId jobId = requester.makeRequest(tokenProxy, JobId.class, getReferenceBackendCaller(reference, index, params)); getExecutorService().submit(new PollingJobStatusRunnable<>(tokenProxy, getTimeout(), jobId, callback, getExecutorService(), jobService)); } @Override public void addFileToTextIndex(final File file, final ResourceIdentifier index, final AddToTextIndexRequestBuilder params, final HodJobCallback callback) throws HodErrorException { final JobId jobId = requester.makeRequest(JobId.class, getFileBackendCaller(file, index, params)); getExecutorService().submit(new PollingJobStatusRunnable<>(getTimeout(), jobId, callback, getExecutorService(), jobService)); } @Override public void addFileToTextIndex(final TokenProxy tokenProxy, final File file, final ResourceIdentifier index, final AddToTextIndexRequestBuilder params, final HodJobCallback callback) throws HodErrorException { final JobId jobId = requester.makeRequest(tokenProxy, JobId.class, getFileBackendCaller(file, index, params)); getExecutorService().submit(new PollingJobStatusRunnable<>(tokenProxy, getTimeout(), jobId, callback, getExecutorService(), jobService)); } @Override public void addFileToTextIndex(final byte[] bytes, final ResourceIdentifier index, final AddToTextIndexRequestBuilder params, final HodJobCallback callback) throws HodErrorException { final JobId jobId = requester.makeRequest(JobId.class, getByteArrayBackendCaller(bytes, index, params)); getExecutorService().submit(new PollingJobStatusRunnable<>(getTimeout(), jobId, callback, getExecutorService(), jobService)); } @Override public void addFileToTextIndex(final TokenProxy tokenProxy, final byte[] bytes, final ResourceIdentifier index, final AddToTextIndexRequestBuilder params, final HodJobCallback callback) throws HodErrorException { final JobId jobId = requester.makeRequest(tokenProxy, JobId.class, getByteArrayBackendCaller(bytes, index, params)); getExecutorService().submit(new PollingJobStatusRunnable<>(tokenProxy, getTimeout(), jobId, callback, getExecutorService(), jobService)); } @Override public void addFileToTextIndex(final InputStream inputStream, final ResourceIdentifier index, final AddToTextIndexRequestBuilder params, final HodJobCallback callback) throws HodErrorException { final JobId jobId = requester.makeRequest(JobId.class, getInputStreamBackendCaller(inputStream, index, params)); getExecutorService().submit(new PollingJobStatusRunnable<>(getTimeout(), jobId, callback, getExecutorService(), jobService)); } @Override public void addFileToTextIndex(final TokenProxy tokenProxy, final InputStream inputStream, final ResourceIdentifier index, final AddToTextIndexRequestBuilder params, final HodJobCallback callback) throws HodErrorException { final JobId jobId = requester.makeRequest(tokenProxy, JobId.class, getInputStreamBackendCaller(inputStream, index, params)); getExecutorService().submit(new PollingJobStatusRunnable<>(tokenProxy, getTimeout(), jobId, callback, getExecutorService(), jobService)); } private Requester.BackendCaller getTextBackendCaller(final Documents documents, final ResourceIdentifier index, final AddToTextIndexRequestBuilder params) { return new Requester.BackendCaller() { @Override public Response makeRequest(final AuthenticationToken authenticationToken) throws HodErrorException { return addToTextIndexBackend.addJsonToTextIndex(authenticationToken, documents, index, params.build()); } }; } private Requester.BackendCaller getUrlBackendCaller(final String url, final ResourceIdentifier index, final AddToTextIndexRequestBuilder params) { return new Requester.BackendCaller() { @Override public Response makeRequest(final AuthenticationToken authenticationToken) throws HodErrorException { return addToTextIndexBackend.addUrlToTextIndex(authenticationToken, url, index, params.build()); } }; } private Requester.BackendCaller getReferenceBackendCaller(final String reference, final ResourceIdentifier index, final AddToTextIndexRequestBuilder params) { return new Requester.BackendCaller() { @Override public Response makeRequest(final AuthenticationToken authenticationToken) throws HodErrorException { return addToTextIndexBackend.addReferenceToTextIndex(authenticationToken, reference, index, params.build()); } }; } private Requester.BackendCaller getFileBackendCaller(final File file, final ResourceIdentifier index, final AddToTextIndexRequestBuilder params) { return new Requester.BackendCaller() { @Override public Response makeRequest(final AuthenticationToken authenticationToken) throws HodErrorException { return addToTextIndexBackend.addFileToTextIndex(authenticationToken, new TypedFile("application/octet-stream", file), index, params.build()); } }; } private Requester.BackendCaller getByteArrayBackendCaller(final byte[] bytes, final ResourceIdentifier index, final AddToTextIndexRequestBuilder params) { return new Requester.BackendCaller() { @Override public Response makeRequest(final AuthenticationToken authenticationToken) throws HodErrorException { return addToTextIndexBackend.addFileToTextIndex(authenticationToken, new TypedByteArrayWithFilename("application/octet-stream", bytes), index, params.build()); } }; } private Requester.BackendCaller getInputStreamBackendCaller(final InputStream inputStream, final ResourceIdentifier index, final AddToTextIndexRequestBuilder params) { return new Requester.BackendCaller() { @Override public Response makeRequest(final AuthenticationToken authenticationToken) throws HodErrorException { try { return addToTextIndexBackend.addFileToTextIndex(authenticationToken, new TypedByteArrayWithFilename("application/octet-stream", IOUtils.toByteArray(inputStream)), index, params.build()); } catch (final IOException e) { throw new RuntimeException("Error reading bytes from stream", e); } } }; } }





© 2015 - 2024 Weber Informatics LLC | Privacy Policy