com.arjuna.webservices.wsarjtx.client.TerminationParticipantClient Maven / Gradle / Ivy
/*
* JBoss, Home of Professional Open Source
* Copyright 2006, Red Hat Middleware LLC, and individual contributors
* as indicated by the @author tags.
* See the copyright.txt in the distribution for a full listing
* of individual contributors.
* This copyrighted material is made available to anyone wishing to use,
* modify, copy, or redistribute it subject to the terms and conditions
* of the GNU Lesser General Public License, v. 2.1.
* This program is distributed in the hope that it will be useful, but WITHOUT A
* WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A
* PARTICULAR PURPOSE. See the GNU Lesser General Public License for more details.
* You should have received a copy of the GNU Lesser General Public License,
* v.2.1 along with this distribution; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston,
* MA 02110-1301, USA.
*
* (C) 2005-2006,
* @author JBoss Inc.
*/
package com.arjuna.webservices.wsarjtx.client;
import java.io.IOException;
import com.arjuna.webservices.HandlerRegistry;
import com.arjuna.webservices.SoapFault;
import com.arjuna.webservices.SoapRegistry;
import com.arjuna.webservices.SoapService;
import com.arjuna.webservices.base.policy.ClientPolicy;
import com.arjuna.webservices.wsaddr.AddressingContext;
import com.arjuna.webservices.wsaddr.AttributedURIType;
import com.arjuna.webservices.wsaddr.EndpointReferenceType;
import com.arjuna.webservices.wsaddr.client.BaseWSAddrClient;
import com.arjuna.webservices.wsaddr.policy.AddressingPolicy;
import com.arjuna.webservices.wsarj.InstanceIdentifier;
import com.arjuna.webservices.wsarjtx.ArjunaTXConstants;
import com.arjuna.webservices.wsarjtx.NotificationType;
/**
* The Client side of the Terminator Coordinator.
* @author kevin
*/
public class TerminationParticipantClient extends BaseWSAddrClient
{
/**
* The client singleton.
*/
private static final TerminationParticipantClient CLIENT = new TerminationParticipantClient() ;
/**
* The completed action.
*/
private final AttributedURIType completedAction =
new AttributedURIType(ArjunaTXConstants.WSARJTX_ACTION_COMPLETED) ;
/**
* The closed action.
*/
private final AttributedURIType closedAction =
new AttributedURIType(ArjunaTXConstants.WSARJTX_ACTION_CLOSED) ;
/**
* The cancelled action.
*/
private final AttributedURIType cancelledAction =
new AttributedURIType(ArjunaTXConstants.WSARJTX_ACTION_CANCELLED) ;
/**
* The faulted action.
*/
private final AttributedURIType faultedAction =
new AttributedURIType(ArjunaTXConstants.WSARJTX_ACTION_FAULTED) ;
/**
* The SOAP fault action.
*/
private final AttributedURIType soapFaultAction =
new AttributedURIType(ArjunaTXConstants.WSARJTX_ACTION_SOAP_FAULT) ;
/**
* The SOAP service representing the client.
*/
private final SoapService soapService ;
/**
* The termination coordinator URI for replies.
*/
private final AttributedURIType terminationCoordinator ;
/**
* Construct the terminator coordinator client.
*/
private TerminationParticipantClient()
{
final HandlerRegistry handlerRegistry = new HandlerRegistry() ;
// Add WS-Addressing
AddressingPolicy.register(handlerRegistry) ;
// Add client policies
ClientPolicy.register(handlerRegistry) ;
soapService = new SoapService(handlerRegistry) ;
final String terminationCoordinatorURI =
SoapRegistry.getRegistry().getServiceURI(ArjunaTXConstants.SERVICE_TERMINATION_COORDINATOR) ;
terminationCoordinator = new AttributedURIType(terminationCoordinatorURI) ;
}
/**
* Send a completed request.
* @param addressingContext addressing context initialised with to and message ID.
* @param identifier The identifier of the initiator.
* @throws SoapFault For any errors.
* @throws IOException for any transport errors.
*/
public void sendCompleted(final AddressingContext addressingContext, final InstanceIdentifier identifier)
throws SoapFault, IOException
{
final EndpointReferenceType endpointReference = getEndpointReference(identifier) ;
sendOneWay(new NotificationType(), addressingContext, soapService, endpointReference,
endpointReference, ArjunaTXConstants.WSARJTX_ELEMENT_COMPLETED_QNAME,
completedAction) ;
}
/**
* Send a closed request.
* @param addressingContext addressing context initialised with to and message ID.
* @param identifier The identifier of the initiator.
* @throws SoapFault For any errors.
* @throws IOException for any transport errors.
*/
public void sendClosed(final AddressingContext addressingContext, final InstanceIdentifier identifier)
throws SoapFault, IOException
{
final EndpointReferenceType endpointReference = getEndpointReference(identifier) ;
sendOneWay(new NotificationType(), addressingContext, soapService, endpointReference,
endpointReference, ArjunaTXConstants.WSARJTX_ELEMENT_CLOSED_QNAME,
closedAction) ;
}
/**
* Send a cancelled request.
* @param addressingContext addressing context initialised with to and message ID.
* @param identifier The identifier of the initiator.
* @throws SoapFault For any errors.
* @throws IOException for any transport errors.
*/
public void sendCancelled(final AddressingContext addressingContext, final InstanceIdentifier identifier)
throws SoapFault, IOException
{
final EndpointReferenceType endpointReference = getEndpointReference(identifier) ;
sendOneWay(new NotificationType(), addressingContext, soapService, endpointReference,
endpointReference, ArjunaTXConstants.WSARJTX_ELEMENT_CANCELLED_QNAME,
cancelledAction) ;
}
/**
* Send a faulted request.
* @param addressingContext addressing context initialised with to and message ID.
* @param identifier The identifier of the initiator.
* @throws SoapFault For any errors.
* @throws IOException for any transport errors.
*/
public void sendFaulted(final AddressingContext addressingContext, final InstanceIdentifier identifier)
throws SoapFault, IOException
{
final EndpointReferenceType endpointReference = getEndpointReference(identifier) ;
sendOneWay(new NotificationType(), addressingContext, soapService, endpointReference,
endpointReference, ArjunaTXConstants.WSARJTX_ELEMENT_FAULTED_QNAME,
faultedAction) ;
}
/**
* Send a fault.
* @param addressingContext The addressing context.
* @param soapFault The SOAP fault.
* @param identifier The arjuna instance identifier.
* @throws SoapFault For any errors.
* @throws IOException for any transport errors.
*/
public void sendSoapFault(final AddressingContext addressingContext, final SoapFault soapFault, final InstanceIdentifier identifier)
throws SoapFault, IOException
{
final EndpointReferenceType endpointReference = getEndpointReference(identifier) ;
sendSoapFault(soapFault, addressingContext, soapService, endpointReference, soapFaultAction) ;
}
/**
* Get the endpoint reference for the specified identifier.
* @param identifier The endpoint reference identifier.
* @return The endpoint reference.
*/
private EndpointReferenceType getEndpointReference(final InstanceIdentifier identifier)
{
final EndpointReferenceType terminatorParticipantEndpoint = new EndpointReferenceType(terminationCoordinator) ;
InstanceIdentifier.setEndpointInstanceIdentifier(terminatorParticipantEndpoint, identifier) ;
return terminatorParticipantEndpoint ;
}
/**
* Get the Terminator Coordinator client singleton.
* @return The Terminator Coordinator client singleton.
*/
public static TerminationParticipantClient getClient()
{
return CLIENT ;
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy