blob: d54964abcdd8fd6cc3a9a0e3f6800df3e1418bb2 [file] [log] [blame]
/*
* Copyright 2004 The Apache Software Foundation.
*
* Licensed under the Apache License, Version 2.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.apache.org/licenses/LICENSE-2.0
*
* 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.apache.kandula.wsat.twopc;
import org.apache.axiom.om.OMElement;
import org.apache.axis2.AxisFault;
import org.apache.axis2.context.OperationContext;
import org.apache.axis2.wsdl.WSDLConstants;
import org.apache.kandula.Constants;
import org.apache.kandula.context.AbstractContext;
import org.apache.kandula.faults.AbstractKandulaException;
import org.apache.kandula.participant.ParticipantTransactionCoordinator;
import org.apache.kandula.storage.StorageFactory;
import org.apache.kandula.storage.Store;
/**
* @author <a href="mailto:thilina@opensource.lk"> Thilina Gunarathne </a>
*/
public class ParticipantPortTypeRawXMLSkeleton {
private OperationContext opContext;
public void setOperationContext(OperationContext opContext) {
this.opContext = opContext;
}
public void prepareOperation(OMElement requestEle) throws AxisFault {
StorageFactory.getInstance().setConfigurationContext(
opContext.getServiceContext().getConfigurationContext());
OMElement header = opContext.getMessageContext(
WSDLConstants.MESSAGE_LABEL_IN_VALUE).getEnvelope().getHeader();
String requesterID = header.getFirstChildWithName(
Constants.REQUESTER_ID_PARAMETER).getText();
Store store = StorageFactory.getInstance().getStore();
AbstractContext context = (AbstractContext) store.get(requesterID);
ParticipantTransactionCoordinator txManager = new ParticipantTransactionCoordinator();
try {
txManager.prepare(context);
} catch (AbstractKandulaException e) {
AxisFault fault = new AxisFault(e);
fault.setFaultCode(e.getFaultCode());
throw fault;
}
}
public void commitOperation(OMElement requestEle) throws AxisFault {
StorageFactory.getInstance().setConfigurationContext(
opContext.getServiceContext().getConfigurationContext());
OMElement header = opContext.getMessageContext(
WSDLConstants.MESSAGE_LABEL_IN_VALUE).getEnvelope().getHeader();
String requesterID = header.getFirstChildWithName(
Constants.REQUESTER_ID_PARAMETER).getText();
Store store = StorageFactory.getInstance().getStore();
AbstractContext context = (AbstractContext) store.get(requesterID);
ParticipantTransactionCoordinator participantTxManager = new ParticipantTransactionCoordinator();
try {
participantTxManager.commit(context);
} catch (AbstractKandulaException e) {
AxisFault fault = new AxisFault(e);
fault.setFaultCode(e.getFaultCode());
throw fault;
}
}
public void rollbackOperation(OMElement requestEle) throws AxisFault {
StorageFactory.getInstance().setConfigurationContext(
opContext.getServiceContext().getConfigurationContext());
OMElement header = opContext.getMessageContext(
WSDLConstants.MESSAGE_LABEL_IN_VALUE).getEnvelope().getHeader();
String requesterID = header.getFirstChildWithName(
Constants.REQUESTER_ID_PARAMETER).getText();
Store store = StorageFactory.getInstance().getStore();
AbstractContext context = (AbstractContext) store.get(requesterID);
ParticipantTransactionCoordinator txManager = new ParticipantTransactionCoordinator();
try {
txManager.rollback(context);
} catch (AbstractKandulaException e) {
AxisFault fault = new AxisFault(e);
fault.setFaultCode(e.getFaultCode());
throw fault;
}
}
}