
rapture.kernel.AsyncApiImplWrapper Maven / Gradle / Ivy
/**
* 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.AsyncApi;
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.dp.WorkOrderStatus;
import rapture.common.shared.async.AsyncReflexScriptPayload;
import rapture.common.shared.async.AsyncReflexReferencePayload;
import rapture.common.shared.async.AsyncStatusPayload;
import rapture.common.shared.async.SetupDefaultWorkflowsPayload;
/**
* This class is a wrapper around the class {@link AsyncApiImpl}. 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 AsyncApiImplWrapper implements AsyncApi, KernelApi {
private static final Logger log = Logger.getLogger(AsyncApiImplWrapper.class);
private AsyncApiImpl apiImpl;
public AsyncApiImplWrapper(Kernel kernel) {
apiImpl = new AsyncApiImpl(kernel);
}
/**
* Returns the underlying implementation object. This should be used when a call is deliberately bypassing entitlement checks.
* @return {@link Async}
*/
public AsyncApiImpl getTrusted() {
return apiImpl;
}
@Override
public void start() {
apiImpl.start();
}
/**
*
*/
@Override
public String asyncReflexScript(CallingContext context, String reflexScript, Map parameters) {
long functionStartTime = System.currentTimeMillis();
AsyncReflexScriptPayload requestObj = new AsyncReflexScriptPayload();
requestObj.setContext(context);
requestObj.setReflexScript(reflexScript);
requestObj.setParameters(parameters);
ContextValidator.validateContext(context, EntitlementSet.Async_asyncReflexScript, requestObj);
long preToPostStartTime = System.currentTimeMillis();
Kernel.getApiHooksService().pre(context, CallName.Async_asyncReflexScript);
String returnValue = apiImpl.asyncReflexScript(context, reflexScript, parameters); Kernel.getApiHooksService().post(context, CallName.Async_asyncReflexScript);
long endFunctionTime = System.currentTimeMillis();
Kernel.getMetricsService().recordTimeDifference("apiMetrics.asyncApi.asyncReflexScript.fullFunctionTime.succeeded", (endFunctionTime-functionStartTime));
Kernel.getMetricsService().recordTimeDifference("apiMetrics.asyncApi.asyncReflexScript.preToPostTime.succeeded", (endFunctionTime-preToPostStartTime));
return returnValue;}
/**
*
*/
@Override
public String asyncReflexReference(CallingContext context, String scriptURI, Map parameters) {
long functionStartTime = System.currentTimeMillis();
AsyncReflexReferencePayload requestObj = new AsyncReflexReferencePayload();
requestObj.setContext(context);
requestObj.setScriptURI(scriptURI);
requestObj.setParameters(parameters);
ContextValidator.validateContext(context, EntitlementSet.Async_asyncReflexReference, requestObj);
long preToPostStartTime = System.currentTimeMillis();
Kernel.getApiHooksService().pre(context, CallName.Async_asyncReflexReference);
String returnValue = apiImpl.asyncReflexReference(context, scriptURI, parameters); Kernel.getApiHooksService().post(context, CallName.Async_asyncReflexReference);
long endFunctionTime = System.currentTimeMillis();
Kernel.getMetricsService().recordTimeDifference("apiMetrics.asyncApi.asyncReflexReference.fullFunctionTime.succeeded", (endFunctionTime-functionStartTime));
Kernel.getMetricsService().recordTimeDifference("apiMetrics.asyncApi.asyncReflexReference.preToPostTime.succeeded", (endFunctionTime-preToPostStartTime));
return returnValue;}
/**
*
*/
@Override
public WorkOrderStatus asyncStatus(CallingContext context, String taskId) {
long functionStartTime = System.currentTimeMillis();
AsyncStatusPayload requestObj = new AsyncStatusPayload();
requestObj.setContext(context);
requestObj.setTaskId(taskId);
ContextValidator.validateContext(context, EntitlementSet.Async_asyncStatus, requestObj);
long preToPostStartTime = System.currentTimeMillis();
Kernel.getApiHooksService().pre(context, CallName.Async_asyncStatus);
WorkOrderStatus returnValue = apiImpl.asyncStatus(context, taskId); Kernel.getApiHooksService().post(context, CallName.Async_asyncStatus);
long endFunctionTime = System.currentTimeMillis();
Kernel.getMetricsService().recordTimeDifference("apiMetrics.asyncApi.asyncStatus.fullFunctionTime.succeeded", (endFunctionTime-functionStartTime));
Kernel.getMetricsService().recordTimeDifference("apiMetrics.asyncApi.asyncStatus.preToPostTime.succeeded", (endFunctionTime-preToPostStartTime));
return returnValue;}
/**
*
*/
@Override
public void setupDefaultWorkflows(CallingContext context, Boolean force) {
long functionStartTime = System.currentTimeMillis();
SetupDefaultWorkflowsPayload requestObj = new SetupDefaultWorkflowsPayload();
requestObj.setContext(context);
requestObj.setForce(force);
ContextValidator.validateContext(context, EntitlementSet.Async_setupDefaultWorkflows, requestObj);
long preToPostStartTime = System.currentTimeMillis();
Kernel.getApiHooksService().pre(context, CallName.Async_setupDefaultWorkflows);
apiImpl.setupDefaultWorkflows(context, force); Kernel.getApiHooksService().post(context, CallName.Async_setupDefaultWorkflows);
long endFunctionTime = System.currentTimeMillis();
Kernel.getMetricsService().recordTimeDifference("apiMetrics.asyncApi.setupDefaultWorkflows.fullFunctionTime.succeeded", (endFunctionTime-functionStartTime));
Kernel.getMetricsService().recordTimeDifference("apiMetrics.asyncApi.setupDefaultWorkflows.preToPostTime.succeeded", (endFunctionTime-preToPostStartTime));
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy