/*
* Copyright 2012 PRODYNA AG
*
* Licensed under the Eclipse Public License (EPL), Version 1.0 (the "License"); you may not use
* this file except in compliance with the License. You may obtain a copy of the License at
*
* http://www.opensource.org/licenses/eclipse-1.0.php or
* http://www.nabucco.org/License.html
*
* Unless required by applicable law or agreed to in writing, software distributed under the
* License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND,
* either express or implied. See the License for the specific language governing permissions
* and limitations under the License.
*/
package org.nabucco.testautomation.schema.ui.rcp.communication.produce;
import org.nabucco.framework.base.facade.datatype.NabuccoSystem;
import org.nabucco.framework.base.facade.datatype.context.ServiceSubContext;
import org.nabucco.framework.base.facade.exception.client.ClientException;
import org.nabucco.framework.base.facade.message.EmptyServiceMessage;
import org.nabucco.framework.base.facade.message.ServiceRequest;
import org.nabucco.framework.base.facade.message.ServiceResponse;
import org.nabucco.framework.plugin.base.component.communication.ServiceDelegateSupport;
import org.nabucco.testautomation.schema.facade.message.AttributeMsg;
import org.nabucco.testautomation.schema.facade.message.SchemaConfigMsg;
import org.nabucco.testautomation.schema.facade.message.SchemaElementMsg;
import org.nabucco.testautomation.schema.facade.service.produce.ProduceSchema;
/**
* ProduceSchemaDelegate<p/>SchemaElement produce service<p/>
*
* @version 1.0
* @author Steffen Schmidt, PRODYNA AG, 2010-04-13
*/
public class ProduceSchemaDelegate extends ServiceDelegateSupport {
private ProduceSchema service;
/**
* Constructs a new ProduceSchemaDelegate instance.
*
* @param service the ProduceSchema.
*/
public ProduceSchemaDelegate(ProduceSchema service) {
super();
this.service = service;
}
/**
* ProduceSchemaElement.
*
* @param subContexts the ServiceSubContext....
* @param message the EmptyServiceMessage.
* @return the SchemaElementMsg.
* @throws ClientException
*/
public SchemaElementMsg produceSchemaElement(EmptyServiceMessage message, ServiceSubContext... subContexts)
throws ClientException {
ServiceRequest<EmptyServiceMessage> request = new ServiceRequest<EmptyServiceMessage>(
super.createServiceContext(subContexts));
request.setRequestMessage(message);
ServiceResponse<SchemaElementMsg> response = null;
Exception exception = null;
if ((service != null)) {
super.handleRequest(request);
long start = NabuccoSystem.getCurrentTimeMillis();
try {
response = service.produceSchemaElement(request);
} catch (Exception e) {
exception = e;
} finally {
long end = NabuccoSystem.getCurrentTimeMillis();
long duration = (end - start);
super.monitorResult(ProduceSchema.class, "produceSchemaElement", duration, exception);
}
if ((response != null)) {
super.handleResponse(response);
return response.getResponseMessage();
}
}
throw new ClientException("Cannot execute service operation: ProduceSchema.produceSchemaElement");
}
/**
* ProduceAttribute.
*
* @param subContexts the ServiceSubContext....
* @param message the EmptyServiceMessage.
* @return the AttributeMsg.
* @throws ClientException
*/
public AttributeMsg produceAttribute(EmptyServiceMessage message, ServiceSubContext... subContexts)
throws ClientException {
ServiceRequest<EmptyServiceMessage> request = new ServiceRequest<EmptyServiceMessage>(
super.createServiceContext(subContexts));
request.setRequestMessage(message);
ServiceResponse<AttributeMsg> response = null;
Exception exception = null;
if ((service != null)) {
super.handleRequest(request);
long start = NabuccoSystem.getCurrentTimeMillis();
try {
response = service.produceAttribute(request);
} catch (Exception e) {
exception = e;
} finally {
long end = NabuccoSystem.getCurrentTimeMillis();
long duration = (end - start);
super.monitorResult(ProduceSchema.class, "produceAttribute", duration, exception);
}
if ((response != null)) {
super.handleResponse(response);
return response.getResponseMessage();
}
}
throw new ClientException("Cannot execute service operation: ProduceSchema.produceAttribute");
}
/**
* ProduceSchemaConfig.
*
* @param subContexts the ServiceSubContext....
* @param message the EmptyServiceMessage.
* @return the SchemaConfigMsg.
* @throws ClientException
*/
public SchemaConfigMsg produceSchemaConfig(EmptyServiceMessage message, ServiceSubContext... subContexts)
throws ClientException {
ServiceRequest<EmptyServiceMessage> request = new ServiceRequest<EmptyServiceMessage>(
super.createServiceContext(subContexts));
request.setRequestMessage(message);
ServiceResponse<SchemaConfigMsg> response = null;
Exception exception = null;
if ((service != null)) {
super.handleRequest(request);
long start = NabuccoSystem.getCurrentTimeMillis();
try {
response = service.produceSchemaConfig(request);
} catch (Exception e) {
exception = e;
} finally {
long end = NabuccoSystem.getCurrentTimeMillis();
long duration = (end - start);
super.monitorResult(ProduceSchema.class, "produceSchemaConfig", duration, exception);
}
if ((response != null)) {
super.handleResponse(response);
return response.getResponseMessage();
}
}
throw new ClientException("Cannot execute service operation: ProduceSchema.produceSchemaConfig");
}
/**
* ProduceSchemaConfigClone.
*
* @param subContexts the ServiceSubContext....
* @param message the SchemaConfigMsg.
* @return the SchemaConfigMsg.
* @throws ClientException
*/
public SchemaConfigMsg produceSchemaConfigClone(SchemaConfigMsg message, ServiceSubContext... subContexts)
throws ClientException {
ServiceRequest<SchemaConfigMsg> request = new ServiceRequest<SchemaConfigMsg>(
super.createServiceContext(subContexts));
request.setRequestMessage(message);
ServiceResponse<SchemaConfigMsg> response = null;
Exception exception = null;
if ((service != null)) {
super.handleRequest(request);
long start = NabuccoSystem.getCurrentTimeMillis();
try {
response = service.produceSchemaConfigClone(request);
} catch (Exception e) {
exception = e;
} finally {
long end = NabuccoSystem.getCurrentTimeMillis();
long duration = (end - start);
super.monitorResult(ProduceSchema.class, "produceSchemaConfigClone", duration, exception);
}
if ((response != null)) {
super.handleResponse(response);
return response.getResponseMessage();
}
}
throw new ClientException("Cannot execute service operation: ProduceSchema.produceSchemaConfigClone");
}
}