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

src.com.ibm.as400.access.DBXARequestDS Maven / Gradle / Ivy

There is a newer version: 11.1
Show newest version
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                                 
//                                                                             
// Filename: DBXARequestDS.java
//                                                                             
// The source code contained herein is licensed under the IBM Public License   
// Version 1.0, which has been approved by the Open Source Initiative.         
// Copyright (C) 1997-2001 International Business Machines Corporation and     
// others. All rights reserved.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.access;



/**
The DBXARequestDS class represents a request datastream to the 
XA server.
**/
class DBXARequestDS
extends DBBaseRequestDS
{
  private static final String copyright = "Copyright (C) 1997-2001 International Business Machines Corporation and others.";




    // Server id.
    private static final int SERVER_XA                      = 0xE00A;


    // Request ids.
    public static final int	REQUESTID_XA_CLOSE     	        = 0x18A0;
    public static final int	REQUESTID_XA_COMMIT    	        = 0x18A1;
    public static final int	REQUESTID_XA_COMPLETE  	        = 0x18A2;
    public static final int	REQUESTID_XA_END     	        = 0x18A3;
    public static final int	REQUESTID_XA_FORGET   	        = 0x18A4;
    public static final int	REQUESTID_XA_OPEN    	        = 0x18A5;
    public static final int	REQUESTID_XA_PREPARE  	        = 0x18A6;
    public static final int	REQUESTID_XA_RECOVER	        = 0x18A7;
    public static final int	REQUESTID_XA_ROLLBACK 	        = 0x18A8;
    public static final int	REQUESTID_XA_START   	        = 0x18A9;



/**
Constructs an XA Server request datastream.

@param requestId                        The request id.
@param rpbId                            The request parameter block id.
@param operationResultBitmap            The operation result bitmap.
@param parameterMarkerDescriptorHandle  The parameter marker descriptor handle.
**/
	public DBXARequestDS(int requestId,
		        	     int rpbId,
				         int operationResultBitmap,
				         int parameterMarkerDescriptorHandle)
    {
	   super(requestId, 
             rpbId, 
             operationResultBitmap,
		     parameterMarkerDescriptorHandle);
	   setServerID(SERVER_XA);
    }



/**
Sets the resource manager ID.

@param value The resource manager ID.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
	void setResourceManagerID(int value)
		throws DBDataStreamException
	{
		addParameter(0x38A0, value);
	}



/**
Sets the XA information.

@param value The XA information.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
	void setXAInformation(byte[] value)
		throws DBDataStreamException
	{
		addParameter(0x38A1, value);
	}



/**
Sets the Xid.

@param value The Xid.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
	void setXid(byte[] value)
		throws DBDataStreamException
	{
		addParameter(0x38A2, value);
	}



/**
Sets the handle.

@param value The handle.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
	void setHandle(int value)
		throws DBDataStreamException
	{
		addParameter(0x38A3, value);
	}



/**
Sets the flags.

@param value The flags.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
	void setFlags(int value)
		throws DBDataStreamException
	{
		addParameter(0x38A5, value);
	}



/**
Sets the count.

@param value The count.
@exception DBDataStreamException If there is not enough space left in the data byte array.
**/
	void setCount(int value)
		throws DBDataStreamException
	{
		addParameter(0x38A6, value);
	}

//@K1A
/**
Sets the CTL Timeout.

@param value The number of seconds
@exception DBDataStreamException if there is not enough space left in the data byte array.
**/
        void setCtlTimeout(int value)
                throws DBDataStreamException
        {
            addParameter(0x38A7, value);
        }

//@K1A
/**
Sets the Lock wait time.

@param value The number of seconds
@exception DBDataStreamException if there is not enough space left in the data byte array.
**/
        void setLockWait(int value)
                throws DBDataStreamException
        {
            addParameter(0x38A9, value);
        }

//@540
/**
Sets whether lock sharing is allowed for loosely coupled transaction branches.

@param value The 'lock sharing' setting: 0=="not shared", 1=="shared".
@exception DBDataStreamException if there is not enough space left in the data byte array.
**/
        void setXALooselyCoupledSupport(int value)
                throws DBDataStreamException
        {
          if (value != 0) {  // 0 is the default, don't bother sending it down
            addParameter(0x38AA, (byte)0xE2);  // "locks can be shared" @PDC value needs to be byte
          }
        }

}











© 2015 - 2025 Weber Informatics LLC | Privacy Policy