com.sun.xml.ws.rx.rm.runtime.transaction.TransactionHandlerImpl Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of webservices-osgi Show documentation
Show all versions of webservices-osgi Show documentation
Metro Web Services Runtime OSGi Bundle
The newest version!
/*
* Copyright (c) 2013, 2022 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.rx.rm.runtime.transaction;
import java.util.logging.Level;
import javax.naming.Context;
import javax.naming.InitialContext;
import javax.naming.NamingException;
import jakarta.transaction.Status;
import jakarta.transaction.SystemException;
import jakarta.transaction.UserTransaction;
import com.sun.istack.Nullable;
import com.sun.istack.logging.Logger;
/**
*
*/
public class TransactionHandlerImpl implements TransactionHandler {
private static final Logger LOGGER = Logger
.getLogger(TransactionHandlerImpl.class);
private UserTransaction userTransaction = null;
/**
* Default constructor.
*/
public TransactionHandlerImpl() {}
@Override
public void begin(int txTimeout) throws TransactionException {
UserTransaction userTransaction = getUserTransaction();
try {
userTransaction.setTransactionTimeout(txTimeout);
if (LOGGER.isLoggable(Level.FINE)) {
LOGGER.fine("Transaction timeout set to " + txTimeout);
}
} catch (final SystemException se) {
String message = "Not able to set transaction timeout on UserTransaction.";
LOGGER.severe(message, se);
throw new TransactionException(message, se);
}
try {
userTransaction.begin();
if (LOGGER.isLoggable(Level.FINE)) {
LOGGER.fine("UserTransaction started.");
}
} catch (final Throwable t) {
String message = "Not able to begin UserTransaction.";
LOGGER.severe(message, t);
throw new TransactionException(message, t);
}
}
@Override
public void commit() throws TransactionException {
UserTransaction userTransaction = getUserTransaction();
try {
userTransaction.commit();
if (LOGGER.isLoggable(Level.FINE)) {
LOGGER.fine("UserTransaction committed successfully.");
}
} catch (final Throwable t) {
String message = "Not able to commit UserTransaction.";
LOGGER.severe(message, t);
throw new TransactionException(message, t);
}
}
@Override
public void rollback() throws TransactionException {
UserTransaction userTransaction = getUserTransaction();
try {
userTransaction.rollback();
if (LOGGER.isLoggable(Level.FINE)) {
LOGGER.fine("UserTransaction rolled back successfully.");
}
} catch (final Throwable t) {
String message = "Not able to roll back UserTransaction.";
LOGGER.severe(message, t);
throw new TransactionException(message, t);
}
}
@Override
public void setRollbackOnly() throws TransactionException {
UserTransaction userTransaction = getUserTransaction();
try {
userTransaction.setRollbackOnly();
if (LOGGER.isLoggable(Level.FINE)) {
LOGGER.fine("UserTransaction marked for roll back successfully.");
}
} catch (final Throwable t) {
String message = "Not able to mark UserTransaction for roll back.";
LOGGER.severe(message, t);
throw new TransactionException(message, t);
}
}
@Override
public boolean userTransactionAvailable() throws TransactionException {
UserTransaction ut = getUserTransaction();
return (ut != null);
}
@Override
public boolean isActive() throws TransactionException {
int status = getStatus();
return status == Status.STATUS_ACTIVE;
}
@Override
public boolean isMarkedForRollback() throws TransactionException {
int status = getStatus();
return status == Status.STATUS_MARKED_ROLLBACK;
}
@Override
public boolean canBegin() {
boolean txExists = transactionExists();
return !txExists;
}
@Override
public boolean transactionExists() throws TransactionException {
int status = getStatus();
boolean noTX = (Status.STATUS_NO_TRANSACTION == status ||
Status.STATUS_COMMITTED == status ||
Status.STATUS_ROLLEDBACK == status);
return !noTX;
}
@Override
public int getStatus() throws TransactionException {
UserTransaction ut = getUserTransaction();
int status = Status.STATUS_NO_TRANSACTION;
try {
status = ut.getStatus();
} catch (final SystemException se) {
String message = "Not able to get UserTransaction status.";
LOGGER.severe(message, se);
throw new TransactionException(message, se);
}
if (LOGGER.isLoggable(Level.FINE)) {
LOGGER.fine("UserTransaction status is: " + status);
}
return status;
}
@Override
public String getStatusAsString() throws TransactionException {
int status = getStatus();
String statusString = null;
switch (status) {
case 0:
statusString = "STATUS_ACTIVE";
break;
case 1:
statusString = "STATUS_MARKED_ROLLBACK";
break;
case 2:
statusString = "STATUS_PREPARED";
break;
case 3:
statusString = "STATUS_COMMITTED";
break;
case 4:
statusString = "STATUS_ROLLEDBACK";
break;
case 5:
statusString = "STATUS_UNKNOWN";
break;
case 6:
statusString = "STATUS_NO_TRANSACTION";
break;
case 7:
statusString = "STATUS_PREPARING";
break;
case 8:
statusString = "STATUS_COMMITTING";
break;
case 9:
statusString = "STATUS_ROLLING_BACK";
break;
default:
statusString = "INVALID VALUE";
break;
}
return statusString;
}
private @Nullable UserTransaction getUserTransaction() {
if (userTransaction != null) {
return userTransaction;
}
try {
Context initialContext = new InitialContext();
userTransaction = (UserTransaction) initialContext
.lookup("java:comp/UserTransaction");
} catch (final NamingException ne) {
if(LOGGER.isLoggable(Level.FINE)) {
String message = "NamingException while looking up UserTransaction from InitialContext. "
+ "Which is expected off server.";
LOGGER.fine(message, ne);
}
}
return userTransaction;
}
}