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

org.gs4tr.gcc.restclient.GCExchange Maven / Gradle / Ivy

package org.gs4tr.gcc.restclient;

import java.io.IOException;
import java.io.InputStream;
import java.util.List;

import org.gs4tr.gcc.restclient.dto.MessageResponse;
import org.gs4tr.gcc.restclient.model.Connector;
import org.gs4tr.gcc.restclient.model.GCFile;
import org.gs4tr.gcc.restclient.model.GCJob;
import org.gs4tr.gcc.restclient.model.GCSubmission;
import org.gs4tr.gcc.restclient.model.GCTask;
import org.gs4tr.gcc.restclient.model.State;
import org.gs4tr.gcc.restclient.model.SubmissionWordCountData;
import org.gs4tr.gcc.restclient.model.WordCountSummary;
import org.gs4tr.gcc.restclient.operation.Connectors;
import org.gs4tr.gcc.restclient.operation.Connectors.ConnectorsResponse;
import org.gs4tr.gcc.restclient.operation.ConnectorsConfig;
import org.gs4tr.gcc.restclient.operation.ConnectorsConfig.ConnectorsConfigResponse;
import org.gs4tr.gcc.restclient.operation.ConnectorsConfig.ConnectorsConfigResponseData;
import org.gs4tr.gcc.restclient.operation.Content;
import org.gs4tr.gcc.restclient.operation.Content.ContentResponse;
import org.gs4tr.gcc.restclient.operation.Content.ContentResponseData;
import org.gs4tr.gcc.restclient.operation.ContentData;
import org.gs4tr.gcc.restclient.operation.ContentData.ContentDataResponse;
import org.gs4tr.gcc.restclient.operation.ContentReference;
import org.gs4tr.gcc.restclient.operation.ContentReference.ContentReferenceResponse;
import org.gs4tr.gcc.restclient.operation.Context;
import org.gs4tr.gcc.restclient.operation.Context.ContextResponse;
import org.gs4tr.gcc.restclient.operation.ContextConfig;
import org.gs4tr.gcc.restclient.operation.ContextConfig.ContextConfigResponse;
import org.gs4tr.gcc.restclient.operation.JobCancel;
import org.gs4tr.gcc.restclient.operation.JobStatus;
import org.gs4tr.gcc.restclient.operation.JobStatus.StatusResponse;
import org.gs4tr.gcc.restclient.operation.JobTasks;
import org.gs4tr.gcc.restclient.operation.JobWordCount;
import org.gs4tr.gcc.restclient.operation.JobWordCount.JobWordCountResponse;
import org.gs4tr.gcc.restclient.operation.Jobs;
import org.gs4tr.gcc.restclient.operation.Jobs.JobsResponse;
import org.gs4tr.gcc.restclient.operation.Jobs.JobsResponseData;
import org.gs4tr.gcc.restclient.operation.SessionStart;
import org.gs4tr.gcc.restclient.operation.SessionStart.SessionStartResponse;
import org.gs4tr.gcc.restclient.operation.SessionTerminate;
import org.gs4tr.gcc.restclient.operation.SubmissionCancel;
import org.gs4tr.gcc.restclient.operation.SubmissionCreate;
import org.gs4tr.gcc.restclient.operation.SubmissionCreate.SubmissionCreateResponse;
import org.gs4tr.gcc.restclient.operation.SubmissionJobs;
import org.gs4tr.gcc.restclient.operation.SubmissionStatus;
import org.gs4tr.gcc.restclient.operation.SubmissionSubmit;
import org.gs4tr.gcc.restclient.operation.SubmissionSubmit.SubmissionSubmitResponse;
import org.gs4tr.gcc.restclient.operation.SubmissionSubmit.SubmissionSubmitResponseData;
import org.gs4tr.gcc.restclient.operation.SubmissionTasks;
import org.gs4tr.gcc.restclient.operation.SubmissionWordCount;
import org.gs4tr.gcc.restclient.operation.SubmissionWordCount.SubmissionWordCountResponse;
import org.gs4tr.gcc.restclient.operation.Submissions;
import org.gs4tr.gcc.restclient.operation.Submissions.SubmissionsResponse;
import org.gs4tr.gcc.restclient.operation.Submissions.SubmissionsResponseData;
import org.gs4tr.gcc.restclient.operation.Tasks;
import org.gs4tr.gcc.restclient.operation.Tasks.TasksResponse;
import org.gs4tr.gcc.restclient.operation.Tasks.TasksResponseData;
import org.gs4tr.gcc.restclient.operation.TasksConfirm;
import org.gs4tr.gcc.restclient.operation.TasksConfirm.TasksConfirmResponse;
import org.gs4tr.gcc.restclient.operation.TasksConfirmCancellation;
import org.gs4tr.gcc.restclient.operation.TasksConfirmCancellation.TaskConfirmCancellationFailure;
import org.gs4tr.gcc.restclient.operation.TasksConfirmCancellation.TasksConfirmCancellationResponse;
import org.gs4tr.gcc.restclient.operation.TasksDownload;
import org.gs4tr.gcc.restclient.operation.TasksError;
import org.gs4tr.gcc.restclient.request.JobListRequest;
import org.gs4tr.gcc.restclient.request.JobRequest;
import org.gs4tr.gcc.restclient.request.PageableRequest;
import org.gs4tr.gcc.restclient.request.SubmissionCreateRequest;
import org.gs4tr.gcc.restclient.request.SubmissionRequest;
import org.gs4tr.gcc.restclient.request.SubmissionSubmitRequest;
import org.gs4tr.gcc.restclient.request.SubmissionsListRequest;
import org.gs4tr.gcc.restclient.request.TaskErrorRequest;
import org.gs4tr.gcc.restclient.request.TaskListRequest;
import org.gs4tr.gcc.restclient.request.TaskRequest;
import org.gs4tr.gcc.restclient.request.TasksRequest;
import org.gs4tr.gcc.restclient.request.UploadContentReferenceRequest;
import org.gs4tr.gcc.restclient.request.UploadFileContextRequest;
import org.gs4tr.gcc.restclient.request.UploadFileRequest;
import org.gs4tr.gcc.restclient.util.APIUtils;
import org.gs4tr.gcc.restclient.util.StringUtils;
import org.w3c.dom.DOMException;

import com.fasterxml.jackson.core.JsonParseException;
import com.fasterxml.jackson.core.JsonProcessingException;
import com.fasterxml.jackson.databind.JsonMappingException;
import com.fasterxml.jackson.databind.ObjectMapper;

public class GCExchange {
    private GCConfig config = null;

    public GCExchange(GCConfig config) {
	this.init(config);
    }
    
    public GCConfig getConfig() {
	return this.config;
    }

    private void init(GCConfig conf) {
	if (StringUtils.IsNullOrWhiteSpace(conf.getApiUrl())) {
	    throw new IllegalArgumentException("APIUrl is required");
	}
	if(StringUtils.IsNullOrWhiteSpace(conf.getBearerToken())) {
	    if (StringUtils.IsNullOrWhiteSpace(conf.getUserName())) {
		throw new IllegalArgumentException("Username is required");
	    }
	    if (StringUtils.IsNullOrWhiteSpace(conf.getPassword())) {
		throw new IllegalArgumentException("Password is required");
	    }
	}

	this.config = conf;
	if (!this.config.getApiUrl().endsWith("/")) {
	    this.config.setApiUrl(this.config.getApiUrl() + "/");
	}

	if(StringUtils.IsNullOrWhiteSpace(this.config.getBearerToken())) {
	    login();
	    try {
		    getConnectors();
		} catch (DOMException e) {
		    throw new IllegalArgumentException("Error parsing response", e);
		} catch (Exception e) {
		    throw new IllegalArgumentException("Incorrect client_secret_key", e);
		}
	}

    }

    private void login() {
	SessionStartResponse response = (SessionStartResponse)APIUtils.doRequest(new SessionStart(config));
	String token = response.getResponseData().getUserSessionKey();
	config.setBearerToken(token);
    }
    
    /**
     * Terminate session
     * 
     * @return Is success
     */
    public Boolean logout() {
	APIUtils.doRequest(new SessionTerminate(config));
	return true;
    }
    
    public void setConnectorKey(String connectorKey) {
	config.setConnectorKey(connectorKey);
    }
    
    /**
     * Get session token created during automated session start
     * 
     * @return Session token
     */
    public String getSessionToken() {
	return config.getBearerToken();
    }
    
    /**
     * Gets listing of all connectors available to the user
     * 
     * @return List of {@link Connector}
     */
    public List getConnectors() {
	ConnectorsResponse response = (ConnectorsResponse)APIUtils.doRequest(new Connectors(config));
	return response.getResponseData();
    }
    
    /**
     * Gets connector config for specified connector token, which includes filetypes, locales and submission config options
     * 
     * @return Connector config as {@link ConnectorsConfigResponseData} including supported locales and file types
     */
    public ConnectorsConfigResponseData getConnectorsConfig() {
	ConnectorsConfigResponse response = (ConnectorsConfigResponse)APIUtils.doRequest(new ConnectorsConfig(config));
	return response.getResponseData();
    }
    
    /**
     * Returns a list of all content objects that have been uploaded for the specified connector that have not yet been submitted
     * 
     * @return Paged list of {@link GCFile}
     */
    public ContentResponseData getContentList() {
	ContentResponse response = (ContentResponse)APIUtils.doRequest(new Content(this.config));
	return response.getResponseData();
    }
    
    /**
     * Returns a list of all content objects that have been uploaded for the specified connector that have not yet been submitted
     * 
     * @param request {@link PageableRequest}
     * @return Paged list of {@link GCFile}
     */
    public ContentResponseData getContentList(PageableRequest request) {
	ContentResponse response = (ContentResponse)APIUtils.doRequest(new Content(this.config, request));
	return response.getResponseData();
    }
    
    /**
     * Upload content for translation. The returned content-id can be used to create a submission
     * 
     * @param request {@link UploadFileRequest}
     * @return Id of uploaded content
     */
    public String uploadContent(UploadFileRequest request){
	ContentDataResponse response = (ContentDataResponse)APIUtils.doRequestWithParameters(new ContentData(config, request));
	return response.getResponseData().getContentId();
    }
    
    /**
     * Upload a reference file which will be associated with the submission and will be available to the translator and reviewer.
     * 
     * @param request {@link UploadContentReferenceRequest}
     * @return Id of uploaded reference
     */
    public String uploadContentReference(UploadContentReferenceRequest request){
	ContentReferenceResponse response = (ContentReferenceResponse)APIUtils.doRequestWithParameters(new ContentReference(config, request));
	return response.getResponseData().getReferenceId();
    }
    
    /**
     * Get a list of all confgured XSLT profiles, for the specified connector
     * 
     * @return List of XSLT profiles
     */
    public List getContextConfigs(){
	ContextConfigResponse response = (ContextConfigResponse)APIUtils.doRequest(new ContextConfig(config));
	return response.getResponseData().getXsltConfigs();
    }
    
    /**
     * Upload context. The returned static url can be used when uploading content
     * 
     * @param request {@link UploadFileContextRequest}
     * @return Static preview url of uploaded context
     */
    public String uploadContext(UploadFileContextRequest request){
	ContextResponse response = (ContextResponse)APIUtils.doRequestWithParameters(new Context(config, request));
	return response.getResponseData().getStaticUrl();
    }
    
    /**
     * Get list of jobs for the specified connector instance
     * 
     * @param request {@link JobListRequest}
     * @return Paged list of {@link GCJob}
     */
    public JobsResponseData getJobsList(JobListRequest request) {
	JobsResponse response = (JobsResponse)APIUtils.doRequest(new Jobs(config, request));
	return response.getResponseData();
    }
    
    /**
     * Get the status of the Job
     * 
     * @param jobId Job Id
     * @return {@link State}
     */
    public State getJobState(Long jobId) {
	StatusResponse response = (StatusResponse)APIUtils.doRequest(new JobStatus(config, new JobRequest(jobId)));
	return response.getResponseData();
    }
    
    /**
     * Gets the tasks list for the specified job
     * 
     * @param jobRequest {@link JobRequest}
     * @return Paged list of {@link GCTask}
     */
    public TasksResponseData getJobTasks(JobRequest jobRequest) {
	TasksResponse response = (TasksResponse)APIUtils.doRequest(new JobTasks(config, jobRequest));
	return response.getResponseData();
    }
    
    /**
     * Get the analyzed wordcount for a job. A xxx response will be returned if the submission is not yet analyzed
     * 
     * @param jobId Job Id
     * @return List of {@link WordCountSummary}
     */
    public List getJobWordCount(Long jobId) {
	JobWordCountResponse response = (JobWordCountResponse)APIUtils.doRequest(new JobWordCount(config, new JobRequest(jobId)));
	return response.getResponseData();
    }
    
    /**
     * Get list of submissions for the specified connector instance
     * 
     * @return Paged list of {@link GCSubmission}
     */
    public SubmissionsResponseData getSubmissionsList() {
	SubmissionsResponse response = (SubmissionsResponse)APIUtils.doRequest(new Submissions(config, null));
	return response.getResponseData();
    }
    
    /**
     * Get list of submissions for the specified connector instance
     * 
     * @param request {@link SubmissionsListRequest}
     * @return Paged list of {@link GCSubmission}
     */
    public SubmissionsResponseData getSubmissionsList(SubmissionsListRequest request) {
	SubmissionsResponse response = (SubmissionsResponse)APIUtils.doRequest(new Submissions(config, request));
	return response.getResponseData();
    }
    
    /**
     * Create a submission from node-ids. The list of node-ids is provided by the plugin that is installed in the client system Notes: 1."connector_locale" is case sensitive 2.Only child nodes(is_parent: 0) can be sent for translation
     * 
     * @param request {@link SubmissionCreateRequest}
     * @return Id of created submission
     */
    public Long createSubmission(SubmissionCreateRequest request) {
	SubmissionCreateResponse response = (SubmissionCreateResponse)APIUtils.doRequest(new SubmissionCreate(config, request));
	return response.getResponseData().getSubmissionId();
    }
    
    /**
     * Gets the jobs list for the specified submission
     * 
     * @param submissionId Submission Id
     * @return Paged list of {@link GCJob}
     */
    public JobsResponseData getSubmissionJobs(Long submissionId) {
	JobsResponse response = (JobsResponse)APIUtils.doRequest(new SubmissionJobs(config, new SubmissionRequest(submissionId)));
	return response.getResponseData();
    }
    
    /**
     * Get the status of the submission
     * 
     * @param submissionId Submission Id
     * @return Submission {@link State}
     */
    public State getSubmissionState(Long submissionId) {
	StatusResponse response = (StatusResponse)APIUtils.doRequest(new SubmissionStatus(config, new SubmissionRequest(submissionId)));
	return response.getResponseData();
    }
    
    /**
     * Cancel submission
     * 
     * @param submissionId Submission Id
     * @return MessageResponse {@link MessageResponse} response with status and message
     */
    public MessageResponse cancelSubmission(Long submissionId) {
	MessageResponse response = (MessageResponse)APIUtils.doRequest(new SubmissionCancel(config, new SubmissionRequest(submissionId)));
	return response;
    }
    
    /**
     * Cancel job
     * 
     * @param jobId Job Id
     * @return MessageResponse {@link MessageResponse} response with status and message
     */
    public MessageResponse cancelJob(Long jobId) {
	MessageResponse response = (MessageResponse)APIUtils.doRequest(new JobCancel(config, new JobRequest(jobId)));
	return response;
    }
    
    /**
     * Submit a list of one or more content objects (content-ids) to one ore more target languages Notes: 1."connector_locale" is case sensitive 2.Only child nodes(is_parent: 0) can be sent for translation
     * 
     * @param request {@link SubmissionSubmitRequest}
     * @return {@link SubmissionSubmitResponseData} object which contains submission id and jobs
     */
    public SubmissionSubmitResponseData submitSubmission(SubmissionSubmitRequest request) {
	SubmissionSubmitResponse response = (SubmissionSubmitResponse)APIUtils.doRequest(new SubmissionSubmit(config, request));
	return response.getResponseData();
    }
    
    /**
     * Gets the tasks list for the specified submission
     * 
     * @param request SubmissionRequest
     * @return Paged list of {@link GCTask}
     */
    public TasksResponseData getSubmissionTasks(SubmissionRequest request) {
	TasksResponse response = (TasksResponse)APIUtils.doRequest(new SubmissionTasks(config, request));
	return response.getResponseData();
    }
    
    /**
     * Get the analyzed wordcount for a submission. A xxx response will be returned if the submission is not yet analyzed
     * 
     * @param submissionId Submission Id
     * @return List of submission {@link SubmissionWordCountData}
     */
    public List getSubmissionWordCount(Long submissionId) {
	SubmissionWordCountResponse response = (SubmissionWordCountResponse)APIUtils.doRequest(new SubmissionWordCount(config, new SubmissionRequest(submissionId)));
	return response.getResponseData().getWordcountData();
    }
    
    /**
     * Get list of tasks for the specified connector instance
     * 
     * @param request {@link TaskListRequest}
     * @return Paged list of {@link GCTask}
     */
    public TasksResponseData getTasksList(TaskListRequest request) {
	TasksResponse response = (TasksResponse)APIUtils.doRequest(new Tasks(config, request));
	return response.getResponseData();
    }
    
    /**
     * Set the Job tasks error for given task
     * 
     * @param request {@link TaskErrorRequest}
     * @return MessageResponse {@link MessageResponse} response with status and message
     */
    public MessageResponse setTaskError(TaskErrorRequest request) {
	MessageResponse response = (MessageResponse)APIUtils.doRequest(new TasksError(config, request));
	return response;
    }
    
    /**
     * Confirm delivery of the downloaded task
     * 
     * @param taskId Task Id
     * @return Is success
     */
    public Boolean confirmTask(Long taskId) {
	TasksConfirmResponse response = (TasksConfirmResponse)APIUtils.doRequest(new TasksConfirm(config, new TaskRequest(taskId)));
	return response.getResponseData().getIsSuccess();
    }
    
    /**
     * Confirm that cancelled task is processed on client side
     * 
     * @param taskIds List of Task Ids to confirm cancellation
     * @return  List of confirm cancellation failures. If list is empty, then result is success for all specified task ids
     */
    public List confirmTaskCancellation(List taskIds) {
	TasksConfirmCancellationResponse response = (TasksConfirmCancellationResponse)APIUtils.doRequest(new TasksConfirmCancellation(config, new TasksRequest(taskIds)));
	return response.getResponseData().getTaskConfirmCancellationFailures();
    }
    
    /**
     * Download the translated content for the specified task ID. If the taskID does not exist, or is not in a complete state, an error code XYZ will be returned
     * 
     * @param taskId Task Id
     * @return Completed task data as InputStream
     */
    public InputStream downloadTask(Long taskId) {
	return APIUtils.doDownload(new TasksDownload(config, new TaskRequest(taskId)));
    }
    
    /**
     * Utility method. Creates json from object
     * 
     * @param object Object to create json
     * @return Requested object in json format
     * @throws JsonProcessingException Json generation exception
     */
    public String createJson(Object object) throws JsonProcessingException {
	ObjectMapper mapper = new ObjectMapper();
	return mapper.writeValueAsString(object);
    }
    
    /**
     * Utility method. Create object of requested class from json
     * 
     * @param json Json string
     * @param outputClass Output class
     * @return Object created from json
     * @throws IOException Json parsing exception
     * @throws JsonMappingException Json parsing exception
     * @throws JsonParseException Json parsing exception
     */
    @SuppressWarnings({ "unchecked", "rawtypes" })
    public Object parseJson(String json, Class outputClass) throws JsonParseException, JsonMappingException, IOException {
	ObjectMapper mapper = new ObjectMapper();
	return mapper.readValue(json, outputClass);
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy