All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.sun.messaging.jmq.jmsserver.persist.jdbc.TransactionDAO Maven / Gradle / Ivy

The newest version!
/*
 * Copyright (c) 2000, 2017 Oracle and/or its affiliates. All rights reserved.
 * Copyright (c) 2021 Contributors to the Eclipse Foundation
 *
 * This program and the accompanying materials are made available under the
 * terms of the Eclipse Public License v. 2.0, which is available at
 * http://www.eclipse.org/legal/epl-2.0.
 *
 * This Source Code may also be made available under the following Secondary
 * Licenses when the conditions for such availability set forth in the
 * Eclipse Public License v. 2.0 are satisfied: GNU General Public License,
 * version 2 with the GNU Classpath Exception, which is available at
 * https://www.gnu.org/software/classpath/license.html.
 *
 * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
 */

package com.sun.messaging.jmq.jmsserver.persist.jdbc;

import com.sun.messaging.jmq.jmsserver.util.BrokerException;
import com.sun.messaging.jmq.jmsserver.data.TransactionUID;
import com.sun.messaging.jmq.jmsserver.data.TransactionState;
import com.sun.messaging.jmq.jmsserver.data.TransactionBroker;
import com.sun.messaging.jmq.jmsserver.core.BrokerAddress;
import com.sun.messaging.jmq.jmsserver.persist.api.TransactionInfo;
import com.sun.messaging.jmq.jmsserver.persist.jdbc.comm.BaseDAO;

import java.sql.Connection;
import java.util.HashMap;
import java.util.List;

/**
 * This class is an interface for the Transaction table which will be implemented by database specific code.
 */
public interface TransactionDAO extends BaseDAO {

    /**
     * Destination table: Holds all the destination in the system.
     *
     * CREATE TABLE MQTXN[C|S] ( ID NUMBER NOT NULL, TYPE INTERGER NOT NULL, STATE
     * INTEGER NOT NULL, AUTO_ROLLBACK INTEGER NOT NULL, XID VARCHAR(100), TXN_STATE LONGVARBINARY NOT NULL, TXN_HOME_BROKER
     * LONGVARBINARY, TXN_BROKERS LONGVARBINARY, STORE_SESSION_ID BIGINT NOT NULL, EXPIRED_TS_COLUMN BIGINT NOT NULL,
     * ACCESSED_TS_COLUMN BIGINT NOT NULL PRIMARY KEY(ID) );
     *
     * ID - Long value of local broker transaction TYPE - Type of transaction, i.e. LOCAL, CLUSTER, or REMOTE STATE - State
     * of the transaction AUTO_ROLLBACK - Transaction rollback mode XID - XID (if any) associated with this transaction
     * TXN_STATE - Serialized Transaction state information TXN_HOME_BROKER - Transaction's home broker for a REMOTE txn
     * (serialized BrokerAddress information) TXN_BROKERS - Transaction's participant brokers for a REMOTE/CLUSTER txn
     * (serialized array of TransactionBroker information) STORE_SESSION_ID - Store session ID associated with the Broker
     * responsible for reaping the transaction EXPIRED_TS_COLUMN - Timestamp when the transaction expired ACCESSED_TS_COLUMN
     * - Timestamp when the transaction was last accessed
     */
    String TABLE = "MQTXN";
    String TABLE_NAME_PREFIX = TABLE + DBConstants.SCHEMA_VERSION;
    String ID_COLUMN = "ID";
    String TYPE_COLUMN = "TYPE";
    String STATE_COLUMN = "STATE";
    String AUTO_ROLLBACK_COLUMN = "AUTO_ROLLBACK";
    String XID_COLUMN = "XID";
    String TXN_STATE_COLUMN = "TXN_STATE";
    String TXN_HOME_BROKER_COLUMN = "TXN_HOME_BROKER";
    String TXN_BROKERS_COLUMN = "TXN_BROKERS";
    String STORE_SESSION_ID_COLUMN = "STORE_SESSION_ID";
    String EXPIRED_TS_COLUMN = "EXPIRED_TS";
    String ACCESSED_TS_COLUMN = "ACCESSED_TS";

    void insert(Connection conn, TransactionUID txnUID, TransactionState txnState, long storeSessionID) throws BrokerException;

    void insert(Connection conn, TransactionUID txnUID, TransactionState txnState, BrokerAddress txnHomeBroker, TransactionBroker[] txnBrokers, int type,
            long storeSessionID) throws BrokerException;

    void updateTransactionState(Connection conn, TransactionUID txnUID, TransactionState state, boolean replaycheck) throws BrokerException;

    void updateTransactionHomeBroker(Connection conn, TransactionUID txnUID, BrokerAddress txnHomeBroker) throws BrokerException;

    void updateTransactionBrokers(Connection conn, TransactionUID txnUID, TransactionBroker[] brokers) throws BrokerException;

    void updateTransactionBrokerState(Connection conn, TransactionUID txnUID, int expectedTxnState, TransactionBroker txnBroker) throws BrokerException;

    void updateAccessedTime(Connection conn, TransactionUID txnUID, long timeStamp) throws BrokerException;

    void delete(Connection conn, TransactionUID txnUID) throws BrokerException;

    TransactionState getTransactionState(Connection conn, TransactionUID txnUID) throws BrokerException;

    BrokerAddress getTransactionHomeBroker(Connection conn, TransactionUID txnUID) throws BrokerException;

    TransactionBroker[] getTransactionBrokers(Connection conn, TransactionUID txnUID) throws BrokerException;

    TransactionInfo getTransactionInfo(Connection conn, TransactionUID txnUID) throws BrokerException;

    long getAccessedTime(Connection conn, TransactionUID txnUID) throws BrokerException;

    List getTransactionsByBroker(Connection conn, String brokerID) throws BrokerException;

    List getRemoteTransactionsByBroker(Connection conn, String brokerID) throws BrokerException;

    HashMap getTransactionStatesByBroker(Connection conn, String brokerID, Long storeSession) throws BrokerException;

    HashMap getRemoteTransactionStatesByBroker(Connection conn, String brokerID, Long storeSession) throws BrokerException;

    int[] getTransactionUsageInfo(Connection conn, TransactionUID txnUID) throws BrokerException;

    void checkTransaction(Connection conn, long txnUID) throws BrokerException;

    boolean hasTransaction(Connection conn, long txnUID) throws BrokerException;
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy