DataAreaImplProxy.java :  » Net » jtopen-7.0 » com » ibm » as400 » access » Java Open Source

Java Open Source » Net » jtopen 7.0 
jtopen 7.0 » com » ibm » as400 » access » DataAreaImplProxy.java
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (IBM Toolbox for Java - OSS version)
//
// Filename: DataAreaImplProxy.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-2004 International Business Machines Corporation and
// others. All rights reserved.
//
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.access;

import java.io.IOException;
import java.lang.reflect.InvocationTargetException;
import java.math.BigDecimal;

/**
Provides implementations of the public Data Area classes,
when used on a client communicating with a proxy server:
 <ul compact>
 <li>DataArea (abstract base class)
 <li>CharacterDataArea
 <li>DecimalDataArea
 <li>LocalDataArea
 <li>LogicalDataArea
 </ul>
**/

class DataAreaImplProxy
extends AbstractProxyImpl
implements DataAreaImpl
{
  DataAreaImplProxy ()
  {
    super ("DataArea");
  }


   /**
   Resets the data area to contain all blanks.
     @exception AS400SecurityException          If a security or authority error occurs.
     @exception ConnectionDroppedException      If the connection is dropped unexpectedly.
     @exception ErrorCompletingRequestException If an error occurs before the request is completed.
     @exception InterruptedException            If this thread is interrupted.
     @exception IOException                     If an error occurs while communicating with the system.
     @exception ObjectDoesNotExistException     If the system object does not exist.
     @exception ServerStartupException          If the host server cannot be started.
     @exception UnknownHostException            If the system cannot be located.
   **/
   public void clear()
       throws AS400SecurityException,
              ErrorCompletingRequestException,
              InterruptedException,
              ObjectDoesNotExistException,
              IOException
   {
     try {
       connection_.callMethod (pxId_, "clear");
     }
     catch (InvocationTargetException e) {
       throw ProxyClientConnection.rethrow5 (e);
     }
   }


   /**
   Creates a character data area with the specified attributes.
     @param length The maximum number of characters in the data area.
            Valid values are 1 through 2000.
     @param initialValue The initial value for the data area.
     @param textDescription The text description for the data area.
            The maximum length is 50 characters.
     @param authority The public authority level for the data area. Valid
            values are *ALL, *CHANGE, *EXCLUDE, *LIBCRTAUT, *USE, or the name
            of an authorization list. The maximum length is 10 characters.
     @exception AS400SecurityException          If a security or authority error occurs.
     @exception ConnectionDroppedException      If the connection is dropped unexpectedly.
     @exception ErrorCompletingRequestException If an error occurs before the request is completed.
     @exception InterruptedException            If this thread is interrupted.
     @exception IOException                     If an error occurs while communicating with the system.
     @exception ObjectAlreadyExistsException    If the system object already exists.
     @exception ObjectDoesNotExistException     If the system object does not exist.
     @exception ServerStartupException          If the host server cannot be started.
     @exception UnknownHostException            If the system cannot be located.
   **/
   public void create(int length, String initialValue,
                      String textDescription, String authority)
       throws AS400SecurityException,
              ErrorCompletingRequestException,
              InterruptedException,
              ObjectAlreadyExistsException,
              ObjectDoesNotExistException,
              IOException
   {
     try {
       connection_.callMethod (pxId_, "create",
                         new Class[] { Integer.TYPE, String.class,
                                       String.class, String.class},
                         new Object[] { new Integer(length), initialValue,
                                        textDescription, authority});
     }
     catch (InvocationTargetException e) {
       throw ProxyClientConnection.rethrow6 (e);
     }
   }


   /**
   Creates a decimal data area with the specified attributes.
     @param length The maximum number of digits in the data area. Valid
            values are 1 through 24.
     @param decimalPositions The number of digits to the right of the decimal
            point. Valid values are 0 through 9.
     @param initialValue The initial value for the data area.
     @param textDescription The text description for the data area. The maximum length is 50 characters.
     @param authority The public authority level for the data area. Valid
            values are *ALL, *CHANGE, *EXCLUDE, *LIBCRTAUT, *USE, or the
            name of an authorization list. The maximum length is 10 characters.
     @exception AS400SecurityException          If a security or authority error occurs.
     @exception ConnectionDroppedException      If the connection is dropped unexpectedly.
     @exception ErrorCompletingRequestException If an error occurs before the request is completed.
     @exception InterruptedException            If this thread is interrupted.
     @exception IOException                     If an error occurs while communicating with the system.
     @exception ObjectAlreadyExistsException    If the system object already exists.
     @exception ObjectDoesNotExistException     If the system object does not exist.
     @exception ServerStartupException          If the host server cannot be started.
     @exception UnknownHostException            If the system cannot be located.
   **/
   public void create(int length, int decimalPositions,
                      BigDecimal initialValue, String textDescription,
                      String authority)
       throws AS400SecurityException,
              ErrorCompletingRequestException,
              InterruptedException,
              ObjectAlreadyExistsException,
              ObjectDoesNotExistException,
              IOException
   {
     try {
       connection_.callMethod (pxId_, "create",
                         new Class[] { Integer.TYPE,
                                       Integer.TYPE,
                                       BigDecimal.class,
                                       String.class, String.class},
                         new Object[] { new Integer(length),
                                        new Integer(decimalPositions),
                                        initialValue,
                                        textDescription, authority});
     }
     catch (InvocationTargetException e) {
       throw ProxyClientConnection.rethrow6 (e);
     }
   }



   /**
   Creates a logical data area with the specified attributes.
     @param initialValue The initial value for the data area.
     @param textDescription The text description for the data area. The maximum length is 50 characters.
     @param authority The public authority level for the data area. Valid
            values are *ALL, *CHANGE, *EXCLUDE, *LIBCRTAUT, *USE, or the
            name of an authorization list. The maximum length is 10 characters.
     @exception AS400SecurityException          If a security or authority error occurs.
     @exception ConnectionDroppedException      If the connection is dropped unexpectedly.
     @exception ErrorCompletingRequestException If an error occurs before the request is completed.
     @exception InterruptedException            If this thread is interrupted.
     @exception IOException                     If an error occurs while communicating with the system.
     @exception ObjectAlreadyExistsException    If the system object already exists.
     @exception ObjectDoesNotExistException     If the system object does not exist.
     @exception ServerStartupException          If the host server cannot be started.
     @exception UnknownHostException            If the system cannot be located.
   **/
   public void create(boolean initialValue, String textDescription,
                      String authority)
       throws AS400SecurityException,
              ErrorCompletingRequestException,
              InterruptedException,
              ObjectAlreadyExistsException,
              ObjectDoesNotExistException,
              IOException
   {
     try {
       connection_.callMethod (pxId_, "create",
                         new Class[] { Boolean.TYPE,
                                       String.class, String.class},
                         new Object[] { new Boolean(initialValue),
                                        textDescription, authority});
     }
     catch (InvocationTargetException e) {
       throw ProxyClientConnection.rethrow6 (e);
     }
   }


   /**
   Removes the data area from the system. Note this method is NOT public.
   It is overridden as a public method in the subclasses that use it.
     @exception AS400SecurityException          If a security or authority error occurs.
     @exception ConnectionDroppedException      If the connection is dropped unexpectedly.
     @exception ErrorCompletingRequestException If an error occurs before the request is completed.
     @exception InterruptedException            If this thread is interrupted.
     @exception ObjectDoesNotExistException     If the object does not exist.
     @exception ServerStartupException          If the host server cannot be started.
     @exception UnknownHostException            If the system cannot be located.
     @exception IOException                     If an error occurs while communicating with the system.
   **/
   public void delete()
       throws AS400SecurityException,
              ErrorCompletingRequestException,
              InterruptedException,
              ObjectDoesNotExistException,
              IOException
   {
     try {
       connection_.callMethod (pxId_, "delete");
     }
     catch (InvocationTargetException e) {
       throw ProxyClientConnection.rethrow5 (e);
     }
   }


   /**
   Returns the number of digits to the right of the decimal point in this data area.
     @return The number of decimal positions.
     @exception AS400SecurityException          If a security or authority error occurs.
     @exception ErrorCompletingRequestException If an error occurs before the request is completed.
     @exception IllegalObjectTypeException      If the system object is not the required type.
     @exception InterruptedException            If this thread is interrupted.
     @exception IOException                     If an error occurs while communicating with the system.
     @exception ObjectDoesNotExistException     If the system object does not exist.
   **/
   public int getDecimalPositions()
        throws AS400SecurityException,
               ErrorCompletingRequestException,
               IllegalObjectTypeException,
               InterruptedException,
               ObjectDoesNotExistException,
               IOException
   {
     try {
       return connection_.callMethod (pxId_, "getDecimalPositions")
                         .getReturnValueInt();
     }
     catch (InvocationTargetException e) {
       Throwable e2 = e.getTargetException ();
       if (e2 instanceof IllegalObjectTypeException)
         throw (IllegalObjectTypeException) e2;
       else
         throw ProxyClientConnection.rethrow5 (e);
     }
   }


   /**
     Returns the size of the data area.
        @return The size of the data area.
     @exception AS400SecurityException          If a security or authority error occurs.
     @exception ErrorCompletingRequestException If an error occurs before the request is completed.
     @exception IllegalObjectTypeException      If the system object is not the required type.
     @exception InterruptedException            If this thread is interrupted.
     @exception IOException                     If an error occurs while communicating with the system.
     @exception ObjectDoesNotExistException     If the system object does not exist.
   **/
   public int getLength()
        throws AS400SecurityException,
               ErrorCompletingRequestException,
               IllegalObjectTypeException,
               InterruptedException,
               ObjectDoesNotExistException,
               IOException
   {
     try {
       return connection_.callMethod (pxId_, "getLength")
                         .getReturnValueInt();
     }
     catch (InvocationTargetException e) {
       Throwable e2 = e.getTargetException ();
       if (e2 instanceof IllegalObjectTypeException)
         throw (IllegalObjectTypeException) e2;
       else
         throw ProxyClientConnection.rethrow5 (e);
     }
   }


   /**
   Returns the data read from the data area.
     @return The decimal data read from the data area.
     @exception AS400SecurityException          If a security or authority error occurs.
     @exception ErrorCompletingRequestException If an error occurs before the request is completed.
     @exception IllegalObjectTypeException      If the system object is not the required type.
     @exception InterruptedException            If this thread is interrupted.
     @exception IOException                     If an error occurs while communicating with the system.
     @exception ObjectDoesNotExistException     If the system object does not exist.
   **/
   // Note that doing a read() will also set the attributes of this
   // object to what is returned from the 400, namely the length and
   // number of decimal positions.
   public BigDecimal readBigDecimal()
        throws AS400SecurityException,
               ErrorCompletingRequestException,
               IllegalObjectTypeException,
               InterruptedException,
               ObjectDoesNotExistException,
               IOException
   {
     try {
       return (BigDecimal) connection_.callMethod (pxId_, "readBigDecimal")
                                      .getReturnValue ();
     }
     catch (InvocationTargetException e) {
       Throwable e2 = e.getTargetException ();
       if (e2 instanceof IllegalObjectTypeException)
         throw (IllegalObjectTypeException) e2;
       else
         throw ProxyClientConnection.rethrow5 (e);
     }
   }


   /**
   Returns the value in the data area.
     @return The data read from the data area.
     @exception AS400SecurityException          If a security or authority error occurs.
     @exception ErrorCompletingRequestException If an error occurs before the request is completed.
     @exception IllegalObjectTypeException      If the system object is not the required type.
     @exception InterruptedException            If this thread is interrupted.
     @exception IOException                     If an error occurs while communicating with the system.
     @exception ObjectDoesNotExistException     If the system object does not exist.
   **/
   public boolean readBoolean()
        throws AS400SecurityException,
               ErrorCompletingRequestException,
               IllegalObjectTypeException,
               InterruptedException,
               ObjectDoesNotExistException,
               IOException
   {
     try {
       return connection_.callMethod (pxId_, "readBoolean")
                         .getReturnValueBoolean();
     }
     catch (InvocationTargetException e) {
       Throwable e2 = e.getTargetException ();
       if (e2 instanceof IllegalObjectTypeException)
         throw (IllegalObjectTypeException) e2;
       else
         throw ProxyClientConnection.rethrow5 (e);
     }
   }


   /**
    Reads the data from the data area.
    It retrieves <i>dataLength</i> bytes beginning at
    <i>dataAreaOffset</i> in the data area. The first byte in
    the data area is at offset 0.
    **/
   public int readBytes(byte[] data, int dataBufferOffset, int dataAreaOffset, int dataLength)
     throws AS400SecurityException,
   ErrorCompletingRequestException,
   IllegalObjectTypeException,
   InterruptedException,
   IOException,
   ObjectDoesNotExistException
   {
     try {
            ProxyReturnValue rv = connection_.callMethod (pxId_, "readBytes",
                         new Class[] { byte[].class, Integer.TYPE, Integer.TYPE, Integer.TYPE },
                         new Object[] { data, new Integer(dataBufferOffset), new Integer(dataAreaOffset), new Integer(dataLength) },
                         new boolean[] { true, false, false, false }, // returnArguments
                         true);
            byte[] returnData = (byte[])rv.getArgument(0);
            System.arraycopy(returnData, 0, data, 0, returnData.length);
            return rv.getReturnValueInt();
     }
     catch (InvocationTargetException e) {
       Throwable e2 = e.getTargetException ();
       if (e2 instanceof IllegalObjectTypeException)
         throw (IllegalObjectTypeException) e2;
       else
         throw ProxyClientConnection.rethrow5 (e);
     }
   }


   /**
   Refreshes the attributes of the data area.
   This method should be called if the underlying IBM i data area has changed
   and it is desired that this object should reflect those changes.
     @exception AS400SecurityException          If a security or authority error occurs.
     @exception ErrorCompletingRequestException If an error occurs before the request is completed.
     @exception IllegalObjectTypeException      If the system object is not the required type.
     @exception InterruptedException            If this thread is interrupted.
     @exception IOException                     If an error occurs while communicating with the system.
     @exception ObjectDoesNotExistException     If the system object does not exist.
   **/
   public void refreshAttributes()
        throws AS400SecurityException,
               ErrorCompletingRequestException,
               IllegalObjectTypeException,
               InterruptedException,
               ObjectDoesNotExistException,
               IOException
   {
     try {
       connection_.callMethod (pxId_, "refreshAttributes");
     }
     catch (InvocationTargetException e) {
       Throwable e2 = e.getTargetException ();
       if (e2 instanceof IllegalObjectTypeException)
         throw (IllegalObjectTypeException) e2;
       else
         throw ProxyClientConnection.rethrow5 (e);
     }
   }


   /**
   Makes the API call to retrieve the data area data and attributes.
     @return The String value read from the data area as a result of
     retrieving the data area's attributes.
     @exception AS400SecurityException          If a security or authority error occurs.
     @exception ErrorCompletingRequestException If an error occurs before the request is completed.
     @exception IllegalObjectTypeException      If the system object is not the required type.
     @exception InterruptedException            If this thread is interrupted.
     @exception IOException                     If an error occurs while communicating with the system.
     @exception ObjectDoesNotExistException     If the system object does not exist.
   **/
   public String retrieve(int dataAreaOffset, int dataLength)
        throws AS400SecurityException,
               ErrorCompletingRequestException,
               IllegalObjectTypeException,
               InterruptedException,
               ObjectDoesNotExistException,
               IOException
   {
     try {
       return (String) connection_.callMethod (pxId_, "retrieve",
                         new Class[] { Integer.TYPE, Integer.TYPE },
                         new Object[] { new Integer(dataAreaOffset), new Integer(dataLength) })
                       .getReturnValue ();
     }
     catch (InvocationTargetException e) {
       Throwable e2 = e.getTargetException ();
       if (e2 instanceof IllegalObjectTypeException)
         throw (IllegalObjectTypeException) e2;
       else
         throw ProxyClientConnection.rethrow5 (e);
     }
   }


   /**
   Makes the API call to retrieve the data area data and attributes.
     @return The String value read from the data area as a result of
     retrieving the data area's attributes.
     @exception AS400SecurityException          If a security or authority error occurs.
     @exception ErrorCompletingRequestException If an error occurs before the request is completed.
     @exception IllegalObjectTypeException      If the system object is not the required type.
     @exception InterruptedException            If this thread is interrupted.
     @exception IOException                     If an error occurs while communicating with the system.
     @exception ObjectDoesNotExistException     If the system object does not exist.
   **/
   public String retrieve(int dataAreaOffset, int dataLength, int type)            //$A2C
        throws AS400SecurityException,
               ErrorCompletingRequestException,
               IllegalObjectTypeException,
               InterruptedException,
               ObjectDoesNotExistException,
               IOException
   {
     try {
       return (String) connection_.callMethod (pxId_, "retrieve",
                         new Class[] { Integer.TYPE, Integer.TYPE, Integer.TYPE },                                   //$A2C
                         new Object[] { new Integer(dataAreaOffset), new Integer(dataLength), new Integer(type) })   //$A2C
                       .getReturnValue ();
     }
     catch (InvocationTargetException e) {
       Throwable e2 = e.getTargetException ();
       if (e2 instanceof IllegalObjectTypeException)
         throw (IllegalObjectTypeException) e2;
       else
         throw ProxyClientConnection.rethrow5 (e);
     }
   }


   /**
   Sets the system, path, and data area type.
   **/
   public void setAttributes(AS400Impl system, QSYSObjectPathName path, int dataAreaType)
     throws IOException
   {
     try {
       connection_.callMethod (pxId_, "setAttributes",
                               new Class[] { AS400Impl.class,
                                             QSYSObjectPathName.class,
                                             Integer.TYPE },
                               new Object[] { system,
                                              path,
                                              new Integer(dataAreaType)
                                            });
     }
     catch (InvocationTargetException e) {
       throw ProxyClientConnection.rethrow1 (e);
     }
   }


   /**
   Writes the data to the data area.
   It writes <i>data.length()</i> characters from <i>data</i> to the
   data area beginning at <i>dataAreaOffset</i>. The first character
   in the data area is at offset 0.
     @param data The data to be written.
     @param dataAreaOffset The offset in the data area at which to start writing.
     @exception AS400SecurityException          If a security or authority error occurs.
     @exception ConnectionDroppedException      If the connection is dropped unexpectedly.
     @exception ErrorCompletingRequestException If an error occurs before the request is completed.
     @exception InterruptedException            If this thread is interrupted.
     @exception IOException                     If an error occurs while communicating with the system.
     @exception ObjectDoesNotExistException     If the system object does not exist.
     @exception ServerStartupException          If the host server cannot be started.
     @exception UnknownHostException            If the system cannot be located.
   **/
   public void write(String data, int dataAreaOffset)
       throws AS400SecurityException,
              ErrorCompletingRequestException,
              InterruptedException,
              ObjectDoesNotExistException,
              IOException
   {
     try {
       connection_.callMethod (pxId_, "write",
                         new Class[] { String.class, Integer.TYPE },
                         new Object[] { data, new Integer(dataAreaOffset) });
     }
     catch (InvocationTargetException e) {
       throw ProxyClientConnection.rethrow5 (e);
     }
   }


   /**
   Writes the data to the data area.
   It writes <i>data.length()</i> characters from <i>data</i> to the
   data area beginning at <i>dataAreaOffset</i>. The first character
   in the data area is at offset 0.
     @param data The data to be written.
     @param dataAreaOffset The offset in the data area at which to start writing.
     @param type The Data Area bidi string type, as defined by the CDRA (Character
                 Data Representataion Architecture). See <a href="BidiStringType.html">
                 BidiStringType</a> for more information and valid values.
     @exception AS400SecurityException          If a security or authority error occurs.
     @exception ConnectionDroppedException      If the connection is dropped unexpectedly.
     @exception ErrorCompletingRequestException If an error occurs before the request is completed.
     @exception InterruptedException            If this thread is interrupted.
     @exception IOException                     If an error occurs while communicating with the system.
     @exception ObjectDoesNotExistException     If the system object does not exist.
     @exception ServerStartupException          If the host server cannot be started.
     @exception UnknownHostException            If the system cannot be located.
   **/
   public void write(String data, int dataAreaOffset, int type)      //$A2C
       throws AS400SecurityException,
              ErrorCompletingRequestException,
              InterruptedException,
              ObjectDoesNotExistException,
              IOException
   {
     try {
       connection_.callMethod (pxId_, "write",
                         new Class[] { String.class, Integer.TYPE , Integer.TYPE},                   //$A2C
                         new Object[] { data, new Integer(dataAreaOffset), new Integer(type) });     //$A2C
     }
     catch (InvocationTargetException e) {
       throw ProxyClientConnection.rethrow5 (e);
     }
   }


   /**
   Writes <i>data</i> to the data area.
     @param data The decimal data to be written.
     @exception AS400SecurityException          If a security or authority error occurs.
     @exception ConnectionDroppedException      If the connection is dropped unexpectedly.
     @exception ErrorCompletingRequestException If an error occurs before the request is completed.
     @exception InterruptedException            If this thread is interrupted.
     @exception IOException                     If an error occurs while communicating with the system.
     @exception ObjectDoesNotExistException     If the system object does not exist.
     @exception ServerStartupException          If the host server cannot be started.
     @exception UnknownHostException            If the system cannot be located.
   **/
   public void write(BigDecimal data)
       throws AS400SecurityException,
              ErrorCompletingRequestException,
              InterruptedException,
              ObjectDoesNotExistException,
              IOException
   {
     try {
       connection_.callMethod (pxId_, "write",
                         new Class[] { BigDecimal.class },
                         new Object[] { data });
     }
     catch (InvocationTargetException e) {
       throw ProxyClientConnection.rethrow5 (e);
     }
   }


   /**
   Writes the value in <i>data</i> to the data area.
     @param data The data to be written.
     @exception AS400SecurityException          If a security or authority error occurs.
     @exception ConnectionDroppedException      If the connection is dropped unexpectedly.
     @exception ErrorCompletingRequestException If an error occurs before the request is completed.
     @exception InterruptedException            If this thread is interrupted.
     @exception IOException                     If an error occurs while communicating with the system.
     @exception ObjectDoesNotExistException     If the system object does not exist.
     @exception ServerStartupException          If the host server cannot be started.
     @exception UnknownHostException            If the system cannot be located.
   **/
   public void write(boolean data)
       throws AS400SecurityException,
              ErrorCompletingRequestException,
              InterruptedException,
              ObjectDoesNotExistException,
              IOException
   {
     try {
       connection_.callMethod (pxId_, "write",
                         new Class[] { Boolean.TYPE },
                         new Object[] { new Boolean(data) });
     }
     catch (InvocationTargetException e) {
       throw ProxyClientConnection.rethrow5 (e);
     }
   }


   /**
    Writes the data to the data area.
    It writes <i>data.length()</i> bytes from <i>data</i> to the
    data area beginning at <i>dataAreaOffset</i>. The first byte
    in the data area is at offset 0.
    **/
   public void write(byte[] data, int dataBufferOffset, int dataAreaOffset, int dataLength)
     throws AS400SecurityException,
   ErrorCompletingRequestException,
   InterruptedException,
   IOException,
   ObjectDoesNotExistException
   {
     try {
       connection_.callMethod (pxId_, "write",
                               new Class[] { byte[].class, Integer.TYPE, Integer.TYPE, Integer.TYPE },
                               new Object[] { data, new Integer(dataBufferOffset), new Integer(dataAreaOffset), new Integer(dataLength) });
     }
     catch (InvocationTargetException e) {
       throw ProxyClientConnection.rethrow5 (e);
     }
   }

}
java2s.com  | Contact Us | Privacy Policy
Copyright 2009 - 12 Demo Source and Support. All rights reserved.
All other trademarks are property of their respective owners.