com.sun.xml.ws.tx.at.internal.WSATGatewayRMPeerRecoveryDelegate Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of webservices-rt Show documentation
Show all versions of webservices-rt Show documentation
This module contains the Metro runtime code.
/*
* Copyright (c) 1997, 2018 Oracle and/or its affiliates. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Distribution License v. 1.0, which is available at
* http://www.eclipse.org/org/documents/edl-v10.php.
*
* SPDX-License-Identifier: BSD-3-Clause
*/
package com.sun.xml.ws.tx.at.internal;
import javax.transaction.xa.XAException;
import javax.transaction.xa.XAResource;
import javax.transaction.xa.Xid;
/**
* Delegates to WSATGatewayRM for peer/delegate recovery.
* The main/only purpose of this class is the special recover call made on WSATGatewayRM to identify the instance
* and/for log location
*
* @author paulparkinson
*/
public class WSATGatewayRMPeerRecoveryDelegate implements XAResource {
String peerLogLocation;
public WSATGatewayRMPeerRecoveryDelegate() {
}
public WSATGatewayRMPeerRecoveryDelegate(String peerLogLocation) {
this.peerLogLocation = peerLogLocation;
}
public void commit(Xid xid, boolean b) throws XAException {
WSATGatewayRM.getInstance().commit(xid, b);
}
public void end(Xid xid, int i) throws XAException {
WSATGatewayRM.getInstance().end(xid, i);
}
public void forget(Xid xid) throws XAException {
WSATGatewayRM.getInstance().forget(xid);
}
public int getTransactionTimeout() throws XAException {
return WSATGatewayRM.getInstance().getTransactionTimeout();
}
public boolean isSameRM(XAResource xaResource) throws XAException {
return WSATGatewayRM.getInstance().isSameRM(xaResource);
}
public int prepare(Xid xid) throws XAException {
return WSATGatewayRM.getInstance().prepare(xid);
}
public Xid[] recover(int i) throws XAException {
return peerLogLocation==null?
WSATGatewayRM.getInstance().recover(i):
WSATGatewayRM.getInstance().recover(i, peerLogLocation);
}
public void rollback(Xid xid) throws XAException {
WSATGatewayRM.getInstance().rollback(xid);
}
public boolean setTransactionTimeout(int i) throws XAException {
return WSATGatewayRM.getInstance().setTransactionTimeout(i);
}
public void start(Xid xid, int i) throws XAException {
WSATGatewayRM.getInstance().start(xid, i);
}
}