com.ibm.as400.access.ObjectList Maven / Gradle / Ivy
Show all versions of jt400 Show documentation
///////////////////////////////////////////////////////////////////////////////
//
// JTOpen (IBM Toolbox for Java - OSS version)
//
// Filename: ObjectList.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-2007 International Business Machines Corporation and
// others. All rights reserved.
//
///////////////////////////////////////////////////////////////////////////////
// @A1 - 07/24/2007 - Changes to addObjectAuthorityCriteria() to enforce
// documented interface restriction related to AUTH_ANY
// @A2 - 07/25/2007 - Changes to load() and getObjects() to obtain and use
// the correct recordLength for the records returned.
///////////////////////////////////////////////////////////////////////////////
package com.ibm.as400.access;
import java.beans.*;
import java.io.*;
import java.util.*;
/**
Represents a list of system objects in a
specific library, multiple libraries, or system-wide.
Implementation note:
This class internally uses the Open List APIs (e.g. QGYOLOBJ).
@see com.ibm.as400.access.ObjectDescription
**/
public class ObjectList implements Serializable
{
static final long serialVersionUID = 5L;
/**
* Selection value representing *ALL.
**/
public static final String ALL = "*ALL";
/**
* Selection value representing *ALLUSR.
**/
public static final String ALL_USER = "*ALLUSR";
/**
* Constant indicating that the auxiliary storage pools that are currently
* part of the the thread's library name space will be searched to locate
* the library. This includes the system ASP (ASP 1), all defined basic
* user ASPs (ASPs 2-32), and, if the thread has an ASP group, the primary
* and secondary ASPs in the thread's ASP group.
*/
public static final String ASP_NAME_ALL = "*"; // @550A
/**
* Constant indicating that the system ASP (ASP 1) and all defined basic user ASPs (ASPs 2-32)
* will be searched to locate the library. No primary or secondary ASPs will be
* searched, even if the thread has an ASP group.
*/
public static final String ASP_NAME_SYSBAS = "*SYSBAS"; // @550A
/**
* Constant indicating if the thread has an ASP group, the primary and secondary ASPs
* in the ASP group will be searched to locate the library. The system ASP (ASP 1) and
* defined basic user ASPs (ASPs 2-32) will not be searched.
*/
public static final String ASP_NAME_CURASPGRP = "*CURASPGRP"; // @550A
/**
* Constant indicating that all available ASPs will be searched. This includes the system
* ASP (ASP 1), all defined basic user ASPs (ASPs 2-32), and all available primary and
* secondary ASPs (ASPs 33-255 with a status of 'Available'). The ASP groups are searched
* in alphabetical order by the primary ASP. The system ASP and all defined basic user
* ASPs are searched after the ASP groups. ASPs and libraries to which the user is not authorized
* are bypassed and no authority error messages are sent. The search ends when the first object
* is found of the specified object name, library name, and object type. If the user is
* not authorized to the object, an authority error message is sent.
*/
public static final String ASP_NAME_ALLAVL = "*ALLAVL"; // @550A
/**
* Constant indicating that only the single ASP named in the auxiliary storage
* pool device name field will be searched.
*/
public static final String ASP_SEARCH_TYPE_ASP = "*ASP"; // @550A
/**
* Constant indicating that all ASPs in the auxiliary storage pool group named
* in the auxiliary storage pool device name field will be searched. The device
* name must be the name of the primary auxiliary storage pool in the group.
*/
public static final String ASP_SEARCH_TYPE_ASPGRP = "*ASPGRP"; // @550A
/**
* Selection value representing an authority of *ALL.
**/
public static final String AUTH_ALL = "*ALL";
/**
* Selection value representing an authority of *ANY.
**/
public static final String AUTH_ANY = "*ANY";
/**
* Selection value representing an authority of *CHANGE.
**/
public static final String AUTH_CHANGE = "*CHANGE";
/**
* Selection value representing a data authority of *ADD.
**/
public static final String AUTH_DATA_ADD = "*ADD";
/**
* Selection value representing a data authority of *DLT.
**/
public static final String AUTH_DATA_DELETE = "*DLT";
/**
* Selection value representing a data authority of *EXECUTE.
**/
public static final String AUTH_DATA_EXECUTE = "*EXECUTE";
/**
* Selection value representing a data authority of *READ.
**/
public static final String AUTH_DATA_READ = "*READ";
/**
* Selection value representing a data authority of *UPD.
**/
public static final String AUTH_DATA_UPDATE = "*UPD";
/**
* Selection value representing an authority of *AUTLMGT.
**/
public static final String AUTH_LIST_MANAGEMENT = "*AUTLMGT";
/**
* Selection value representing an object authority of *OBJALTER.
**/
public static final String AUTH_OBJECT_ALTER = "*OBJALTER";
/**
* Selection value representing an object authority of *OBJEXIST.
**/
public static final String AUTH_OBJECT_EXISTENCE = "*OBJEXIST";
/**
* Selection value representing an object authority of *OBJMGT.
**/
public static final String AUTH_OBJECT_MANAGEMENT = "*OBJMGT";
/**
* Selection value representing an object authority of *OBJOPR.
**/
public static final String AUTH_OBJECT_OPERATIONAL = "*OBJOPR";
/**
* Selection value representing an object authority of *OBJREF.
**/
public static final String AUTH_OBJECT_REFERENCE = "*OBJREF";
/**
* Selection value representing an authority of *USE.
**/
public static final String AUTH_USE = "*USE";
/**
* Selection value representing *CURLIB.
**/
public static final String CURRENT_LIBRARY = "*CURLIB";
/**
* Selection value representing *IBM.
**/
public static final String IBM = "*IBM";
/**
* Selection value representing *LIBL.
**/
public static final String LIBRARY_LIST = "*LIBL";
/**
* Selection value representing any status.
* @see #addObjectSelectionCriteria
**/
public static final byte STATUS_ANY = (byte)0x5C; // EBCDIC '*'
/**
* Selection value representing *USRLIBL.
**/
public static final String USER_LIBRARY_LIST = "*USRLIBL";
private static final byte BINARY = (byte)0xC2; // EBCDIC 'B'
private static final byte CHAR = (byte)0xC3; // EBCDIC 'C'
private static final byte STRUCT = (byte)0xE2; // EBCDIC 'S'
private AS400 system_;
private int length_;
private int recLen_; // Length of a single record; should never be zero for this API @A2A
private byte[] handle_; // handle that references the user space used by the open list APIs
private byte[] handleToClose_; // used to close a previously opened list
private boolean isConnected_;
// Library authority criteria
private int currentLibAuthKey_ = 0;
private String[] libAuthKeys_ = new String[10];
// Library authority criteria
private int currentObjectAuthKey_ = 0;
private String[] objectAuthKeys_ = new String[11];
// Information status selection criteria
private int currentStatusKey_ = 0;
private byte[] statusKeys_ = new byte[5];
private boolean statusSelection_ = true;
// Attributes to retrieve
private int currentKey_ = 0;
private int[] keys_ = new int[1];
// Sort keys
private int currentSortKey_ = 0;
private int[] sortKeys_ = new int[1];
private boolean[] sortOrders_ = new boolean[1];
private String objectName_;
private String objectLibrary_;
private String objectType_;
private String aspDeviceName_; // @550A
private String aspSearchType_ = ASP_SEARCH_TYPE_ASP; // @550A
/**
* Constructs an ObjectList object. The selection values default to:
*
* - Object library - {@link #ALL ALL}
*
- Object name - {@link #ALL ALL}
*
- Object type - {@link #ALL ALL}
*
* @param system The system.
**/
public ObjectList(AS400 system)
{
this(system, ALL, ALL, ALL);
}
/**
* Constructs an ObjectList with the specified selection criteria.
* @param system The system.
* @param objectLibrary The library or set of libraries that are searched for objects.
* Valid values are a specific name, a generic name, or one of the following
* special values:
*
* - {@link #ALL ALL} - All libraries are searched.
*
- {@link #ALL_USER ALL_USER} - All user libraries are searched.
*
- {@link #CURRENT_LIBRARY CURRENT_LIBRARY} - The current library is searched.
*
- {@link #LIBRARY_LIST LIBRARY_LIST} - The library list is searched.
*
- {@link #USER_LIBRARY_LIST USER_LIBRARY_LIST} - The user portion of the library list is searched.
*
* @param objectName The object name. Valid values are a specific name, a generic
* name, or one of the following special values:
*
* - {@link #ALL ALL} - All object names are searched.
*
- {@link #ALL_USER ALL_USER} - All objects that are libraries in QSYS or the
* library list are searched. The object library
* must either be {@link #LIBRARY_LIST LIBRARY_LIST} or QSYS. The object type
* must be *LIB. A list of user libraries is returned.
*
- {@link #IBM IBM} - All objects that are libraries in QSYS or the library
* list are searched. The object library must either be {@link #LIBRARY_LIST LIBRARY_LIST}
* or QSYS. The object type must be *LIB. A list of saved (SAVLIB) and restored (RSTLIB)
* libraries is returned.
*
* @param objectType The type of objects that are searched. Valid values include
* a specific object type (*LIB, *FILE, *OUTQ, etc) or {@link #ALL ALL}.
**/
public ObjectList(AS400 system, String objectLibrary, String objectName, String objectType)
{
if (system == null) throw new NullPointerException("system");
if (objectLibrary == null) throw new NullPointerException("objectLibrary");
if (objectName == null) throw new NullPointerException("objectName");
if (objectType == null) throw new NullPointerException("objectType");
system_ = system;
objectLibrary_ = QSYSObjectPathName.toQSYSName(objectLibrary);//@O5C
objectName_ = QSYSObjectPathName.toQSYSName(objectName);//@O5C
objectType_ = objectType.toUpperCase();//@O5C
}
//@550A
/**
* Constructs an ObjectList with the specified selection criteria.
* @param system The system.
* @param objectLibrary The library or set of libraries that are searched for objects.
* Valid values are a specific name, a generic name, or one of the following
* special values:
*
* - {@link #ALL ALL} - All libraries are searched.
*
- {@link #ALL_USER ALL_USER} - All user libraries are searched.
*
- {@link #CURRENT_LIBRARY CURRENT_LIBRARY} - The current library is searched.
*
- {@link #LIBRARY_LIST LIBRARY_LIST} - The library list is searched.
*
- {@link #USER_LIBRARY_LIST USER_LIBRARY_LIST} - The user portion of the library list is searched.
*
* @param objectName The object name. Valid values are a specific name, a generic
* name, or one of the following special values:
*
* - {@link #ALL ALL} - All object names are searched.
*
- {@link #ALL_USER ALL_USER} - All objects that are libraries in QSYS or the
* library list are searched. The object library
* must either be {@link #LIBRARY_LIST LIBRARY_LIST} or QSYS. The object type
* must be *LIB. A list of user libraries is returned.
*
- {@link #IBM IBM} - All objects that are libraries in QSYS or the library
* list are searched. The object library must either be {@link #LIBRARY_LIST LIBRARY_LIST}
* or QSYS. The object type must be *LIB. A list of saved (SAVLIB) and restored (RSTLIB)
* libraries is returned.
*
* @param objectType The type of objects that are searched. Valid values include
* a specific object type (*LIB, *FILE, *OUTQ, etc) or {@link #ALL ALL}.
* @param aspDeviceName The name of an auxiliary storage pool (ASP) device in which storage is
* allocated for the library that contains the object or one of the following special values:
*
* - {@link #ASP_NAME_ALL ASP_NAME_ALL} - The ASPs in the thread's library name space.
* - {@link #ASP_NAME_ALLAVL ASP_NAME_ALLAVL} - All available ASPs.
* - {@link #ASP_NAME_CURASPGRP ASP_NAME_CURASPGRP} - The ASPs in the current thread's ASP group.
* - {@link #ASP_NAME_SYSBAS ASP_NAME_SYSBAS} - The system ASP (ASP 1) and defined basic user ASPs (ASPs 2-32).
*
**/
public ObjectList(AS400 system, String objectLibrary, String objectName, String objectType, String aspDeviceName)
{
if (system == null) throw new NullPointerException("system");
if (objectLibrary == null) throw new NullPointerException("objectLibrary");
if (objectName == null) throw new NullPointerException("objectName");
if (objectType == null) throw new NullPointerException("objectType");
system_ = system;
objectLibrary_ = QSYSObjectPathName.toQSYSName(objectLibrary);//@O5C
objectName_ = QSYSObjectPathName.toQSYSName(objectName);//@O5C
objectType_ = objectType.toUpperCase();//@O5C
aspDeviceName_ = aspDeviceName;
}
/**
* Adds a library authority as part of the selection criteria for generating
* the list of objects. Libraries for which the user has the specified authorities
* are searched. If no library authority criteria are added, the default is
* {@link #AUTH_DATA_EXECUTE AUTH_DATA_EXECUTE}. A maximum of 10 authorities
* can be added.
* @param authority The authority to search. Valid values are:
*
* - {@link #AUTH_ALL AUTH_ALL} - All authority. This consists of all 5 object
* authorities and all 5 data authorities.
*
- {@link #AUTH_CHANGE AUTH_CHANGE} - Change authority. This consists of all 5
* data authorities and object operational authority.
*
- {@link #AUTH_USE AUTH_USE} - Use authority. This consists of the read and
* execute data authorities and object operational authority.
*
- {@link #AUTH_OBJECT_OPERATIONAL AUTH_OBJECT_OPERATIONAL} - Object operational authority.
*
- {@link #AUTH_OBJECT_MANAGEMENT AUTH_OBJECT_MANAGEMENT} - Object management authority.
*
- {@link #AUTH_OBJECT_EXISTENCE AUTH_OBJECT_EXISTENCE} - Object existence authority.
*
- {@link #AUTH_OBJECT_ALTER AUTH_OBJECT_ALTER} - Alter authority.
*
- {@link #AUTH_OBJECT_REFERENCE AUTH_OBJECT_REFERENCE} - Reference authority.
*
- {@link #AUTH_DATA_READ AUTH_DATA_READ} - Read authority.
*
- {@link #AUTH_DATA_ADD AUTH_DATA_ADD} - Add authority.
*
- {@link #AUTH_DATA_UPDATE AUTH_DATA_UPDATE} - Update authority.
*
- {@link #AUTH_DATA_DELETE AUTH_DATA_DELETE} - Delete authority.
*
- {@link #AUTH_DATA_EXECUTE AUTH_DATA_EXECUTE} - Execute authority.
*
* @see #clearLibraryAuthorityCriteria
**/
public void addLibraryAuthorityCriteria(String authority)
{
if (authority == null) throw new NullPointerException("authority");
if (!authority.equals(AUTH_ALL) &&
!authority.equals(AUTH_CHANGE) &&
!authority.equals(AUTH_USE) &&
!authority.equals(AUTH_OBJECT_OPERATIONAL) &&
!authority.equals(AUTH_OBJECT_MANAGEMENT) &&
!authority.equals(AUTH_OBJECT_EXISTENCE) &&
!authority.equals(AUTH_OBJECT_ALTER) &&
!authority.equals(AUTH_OBJECT_REFERENCE) &&
!authority.equals(AUTH_DATA_READ) &&
!authority.equals(AUTH_DATA_ADD) &&
!authority.equals(AUTH_DATA_UPDATE) &&
!authority.equals(AUTH_DATA_DELETE) &&
!authority.equals(AUTH_DATA_EXECUTE))
{
throw new ExtendedIllegalArgumentException("authority", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
}
if (currentLibAuthKey_ >= 10)
{
if (Trace.traceOn_) Trace.log(Trace.ERROR, "Too many authorities added to ObjectList.");
throw new ExtendedIllegalArgumentException("authority", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
}
libAuthKeys_[currentLibAuthKey_++] = authority;
resetHandle();
}
/**
* Adds an object attribute to retrieve when this list is built.
* The attribute is cached as part of the ObjectDescription objects
* that are returned by this list, so that another call to the system
* is not necessary. Adding attributes to retrieve may increase list
* build time on the system, as well as increasing the amount of
* storage used to hold the list on the system.
*
* The object NAME, LIBRARY, and TYPE are always retrieved. By
* default, these are the only attributes that are retrieved.
* If no other attributes are added, the statuses of the objects (returned
* by {@link com.ibm.as400.access.ObjectDescription#getStatus ObjectDescription.getStatus()})
* are unknown. Any attributes that are not retrieved via this interface
* will require another call to the system to retrieve them when
* {@link com.ibm.as400.access.ObjectDescription#getValue ObjectDescription.getValue()}
* is called.
* The exceptions to this are the various attributes that represent Date objects,
* as they need to be converted from system timestamp format, which always requires
* another call to the system.
* @param attribute The attribute to retrieve. Valid values include
* any of the attributes on the {@link com.ibm.as400.access.ObjectDescription ObjectDescription} class.
* @see #clearObjectAttributesToRetrieve
**/
public void addObjectAttributeToRetrieve(int attribute)
{
if (attribute < 200)
{
throw new ExtendedIllegalArgumentException("attribute", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
}
if (attribute == ObjectDescription.NAME ||
attribute == ObjectDescription.LIBRARY ||
attribute == ObjectDescription.TYPE)
{
return;
}
for (int i=0; i= keys_.length)
{
int[] temp = keys_;
keys_ = new int[temp.length*2];
System.arraycopy(temp, 0, keys_, 0, temp.length);
}
keys_[currentKey_++] = attribute;
resetHandle();
}
/**
* Adds an object attribute used to sort the list. The attribute
* is automatically added as an attribute to retrieve.
*
* The list of object attributes to sort on is maintained internally even when this ObjectList is closed and re-used.
* To start over with a new set of object attributes to sort on, call {@link #clearObjectAttributesToSortOn clearObjectAttributesToSortOn()}.
* @param attribute The object attribute on which to sort.
* Possible values are all object attributes contained in the {@link com.ibm.as400.access.ObjectDescription ObjectDescription} class,
* excluding the following:
*
* - {@link com.ibm.as400.access.ObjectDescription#LIBRARY ObjectDescription.LIBRARY}
*
- {@link com.ibm.as400.access.ObjectDescription#NAME ObjectDescription.NAME}
*
- {@link com.ibm.as400.access.ObjectDescription#TYPE ObjectDescription.TYPE}
*
* @param sortOrder true to sort ascending; false to sort descending.
* @see #clearObjectAttributesToSortOn
* @see #addObjectAttributeToRetrieve
* @see com.ibm.as400.access.ObjectDescription
**/
public void addObjectAttributeToSortOn(int attribute, boolean sortOrder)
{
if (attribute < 200 || attribute > 9999)
{
throw new ExtendedIllegalArgumentException("attribute", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
}
addObjectAttributeToRetrieve(attribute);
if (currentSortKey_ >= sortKeys_.length)
{
int[] temp = sortKeys_;
sortKeys_ = new int[temp.length*2];
System.arraycopy(temp, 0, sortKeys_, 0, temp.length);
boolean[] tempSort = sortOrders_;
sortOrders_ = new boolean[tempSort.length*2];
System.arraycopy(tempSort, 0, sortOrders_, 0, tempSort.length);
}
sortKeys_[currentSortKey_] = attribute;
sortOrders_[currentSortKey_++] = sortOrder;
resetHandle();
}
/**
* Adds an object authority as part of the selection criteria for generating
* the list of objects. Objects for which the user has the specified authorities
* are searched. If no object authority criteria are added, the default is
* {@link #AUTH_ANY AUTH_ANY}. A maximum of 11 authorities
* can be added.
* @param authority The authority to search. Valid values are:
*
* - {@link #AUTH_ALL AUTH_ALL} - All authority. This consists of all 5 object
* authorities and all 5 data authorities.
*
- {@link #AUTH_CHANGE AUTH_CHANGE} - Change authority. This consists of all 5
* data authorities and object operational authority.
*
- {@link #AUTH_USE AUTH_USE} - Use authority. This consists of the read and
* execute data authorities and object operational authority.
*
- {@link #AUTH_LIST_MANAGEMENT AUTH_LIST_MANAGEMENT} - Authorization list management
* authority. This value is valid only for objects whose type is *AUTL. It is
* ignored for all other object types.
*
- {@link #AUTH_OBJECT_OPERATIONAL AUTH_OBJECT_OPERATIONAL} - Object operational authority.
*
- {@link #AUTH_OBJECT_MANAGEMENT AUTH_OBJECT_MANAGEMENT} - Object management authority.
*
- {@link #AUTH_OBJECT_EXISTENCE AUTH_OBJECT_EXISTENCE} - Object existence authority.
*
- {@link #AUTH_OBJECT_ALTER AUTH_OBJECT_ALTER} - Alter authority.
*
- {@link #AUTH_OBJECT_REFERENCE AUTH_OBJECT_REFERENCE} - Reference authority.
*
- {@link #AUTH_DATA_READ AUTH_DATA_READ} - Read authority.
*
- {@link #AUTH_DATA_ADD AUTH_DATA_ADD} - Add authority.
*
- {@link #AUTH_DATA_UPDATE AUTH_DATA_UPDATE} - Update authority.
*
- {@link #AUTH_DATA_DELETE AUTH_DATA_DELETE} - Delete authority.
*
- {@link #AUTH_DATA_EXECUTE AUTH_DATA_EXECUTE} - Execute authority.
*
- {@link #AUTH_ANY AUTH_ANY} - Any authority other than *EXCLUDE. If this value
* is specified, no other values can be specified.
*
* @see #clearObjectAuthorityCriteria
**/
public void addObjectAuthorityCriteria(String authority)
{
if (authority == null) throw new NullPointerException("authority");
if (!authority.equals(AUTH_ALL) &&
!authority.equals(AUTH_CHANGE) &&
!authority.equals(AUTH_USE) &&
!authority.equals(AUTH_LIST_MANAGEMENT) &&
!authority.equals(AUTH_OBJECT_OPERATIONAL) &&
!authority.equals(AUTH_OBJECT_MANAGEMENT) &&
!authority.equals(AUTH_OBJECT_EXISTENCE) &&
!authority.equals(AUTH_OBJECT_ALTER) &&
!authority.equals(AUTH_OBJECT_REFERENCE) &&
!authority.equals(AUTH_DATA_READ) &&
!authority.equals(AUTH_DATA_ADD) &&
!authority.equals(AUTH_DATA_UPDATE) &&
!authority.equals(AUTH_DATA_DELETE) &&
!authority.equals(AUTH_DATA_EXECUTE) &&
!authority.equals(AUTH_ANY))
{
throw new ExtendedIllegalArgumentException("authority", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
}
if (currentObjectAuthKey_ >= 11)
{
if (Trace.traceOn_) Trace.log(Trace.ERROR, "Too many authorities added to ObjectList.");
throw new ExtendedIllegalArgumentException("authority", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
}
// Start of changes for change flag --------------------------- @A1A
// Following code is to enforce Javadoc which states:
// If this value [AUTH_ANY] is specified, no other values can be specified.
if ((authority.equals(AUTH_ANY)) && (currentObjectAuthKey_ != 0))
{
// If AUTH_ANY is specified, then it must be the first/only entry
if (Trace.traceOn_) Trace.log(Trace.ERROR, "Attempt to add AUTH_ANY auth after other auth was added.");
throw new ExtendedIllegalArgumentException("authority", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
}
if ((currentObjectAuthKey_ > 0) && // Adding auth beyond 1st auth in list -AND-
(objectAuthKeys_[0].equals(AUTH_ANY))) // first auth in list is AUTH_ANY
{
// If AUTH_ANY was already specified, cannot add another auth to the list.
if (Trace.traceOn_) Trace.log(Trace.ERROR, "Attempt to add auth after AUTH_ANY auth was added.");
throw new ExtendedIllegalArgumentException("authority", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
}
// End of changes for change flag ----------------------------- @A1A
objectAuthKeys_[currentObjectAuthKey_++] = authority;
resetHandle();
}
/**
* Adds an object attribute used to filter the list. If no statuses are
* added as selection criteria, the default is to include objects with
* {@link #STATUS_ANY STATUS_ANY}. A maximum of 5 statuses can be added.
* @param status The object information status criteria. Possible values
* include:
*
* - {@link com.ibm.as400.access.ObjectDescription#STATUS_NO_AUTHORITY ObjectDescription.STATUS_NO_AUTHORITY} - Objects that
* do not meet the authorities specified in the object authority criteria
* for this user. See {@link #addObjectAuthorityCriteria addObjectAuthorityCriteria}.
*
- {@link com.ibm.as400.access.ObjectDescription#STATUS_DAMAGED ObjectDescription.STATUS_DAMAGED} - Objects that are damaged.
*
- {@link com.ibm.as400.access.ObjectDescription#STATUS_LOCKED ObjectDescription.STATUS_LOCKED} - Objects that are locked.
*
- {@link com.ibm.as400.access.ObjectDescription#STATUS_PARTIALLY_DAMAGED ObjectDescription.STATUS_PARTIALLY_DAMAGED} - Objects
* that are partially damaged.
*
- {@link #STATUS_ANY ObjectList.STATUS_ANY} - Objects with any status.
*
* @see #clearObjectSelectionCriteria
* @see #setObjectSelection
**/
public void addObjectSelectionCriteria(byte status)
{
if (status != ObjectDescription.STATUS_NO_AUTHORITY &&
status != ObjectDescription.STATUS_DAMAGED &&
status != ObjectDescription.STATUS_LOCKED &&
status != ObjectDescription.STATUS_PARTIALLY_DAMAGED &&
status != STATUS_ANY)
{
throw new ExtendedIllegalArgumentException("status", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
}
if (currentStatusKey_ >= 5)
{
if (Trace.traceOn_) Trace.log(Trace.ERROR, "Too many statuses specified for ObjectList.");
throw new ExtendedIllegalArgumentException("status", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
}
statusKeys_[currentStatusKey_] = status;
resetHandle();
}
/**
* Clears the library authority criteria used to filter the list.
* @see #addLibraryAuthorityCriteria
**/
public void clearLibraryAuthorityCriteria()
{
currentLibAuthKey_ = 0;
libAuthKeys_ = new String[10];
resetHandle();
}
/**
* Clears the object attribtues to retrieve as part of this list.
* This resets the attributes to retrieve back to the default
* NAME, LIBRARY, and TYPE.
* @see #addObjectAttributeToRetrieve
**/
public void clearObjectAttributesToRetrieve()
{
keys_ = new int[1];
currentKey_ = 0;
resetHandle();
}
/**
* Clears the object attributes used to sort the list. This resets all of the
* object sort parameters to their default values.
* @see #addObjectAttributeToSortOn
**/
public void clearObjectAttributesToSortOn()
{
currentSortKey_ = 0;
sortKeys_ = new int[1];
sortOrders_ = new boolean[1];
resetHandle();
}
/**
* Clears the object authority criteria used to filter the list.
* @see #addObjectAuthorityCriteria
**/
public void clearObjectAuthorityCriteria()
{
currentObjectAuthKey_ = 0;
objectAuthKeys_ = new String[11];
resetHandle();
}
/**
* Clears the object statuses used to filter the list and resets the
* object selection to include objects in the list (true).
* @see #addObjectSelectionCriteria
* @see #setObjectSelection
**/
public void clearObjectSelectionCriteria()
{
currentStatusKey_ = 0;
statusKeys_ = new byte[5];
statusSelection_ = true;
resetHandle();
}
/**
* Closes the object list on the system.
* This releases any system resources previously in use by this object list.
* This will not close the connection to the Host Server job held by the associated AS400 object.
* @exception AS400Exception If the system returns an error message.
* @exception AS400SecurityException If a security or authority error occurs.
* @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 object does not exist on the system.
* @see #load
**/
public synchronized void close() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException
{
if (!isConnected_)
{
return;
}
if (handleToClose_ != null && (handle_ == null || handle_ == handleToClose_))
{
handle_ = handleToClose_;
handleToClose_ = null;
}
if (Trace.traceOn_)
{
Trace.log(Trace.DIAGNOSTIC, "Closing object list with handle: ", handle_);
}
try {
ListUtilities.closeList(system_, handle_);
}
finally {
isConnected_ = false;
handle_ = null;
}
if (handleToClose_ != null) // Just in case.
{
handle_ = handleToClose_;
handleToClose_ = null;
close();
}
}
private void ensureSelectionKey(int key)
{
for (int i=0; i 0 && sortKeys_[found-1] == key) return;
int[] temp = sortKeys_;
boolean[] tempOrders = sortOrders_;
sortKeys_ = new int[temp.length+1];
sortOrders_ = new boolean[temp.length+1];
System.arraycopy(temp, 0, sortKeys_, 0, found);
System.arraycopy(tempOrders, 0, sortOrders_, 0, found);
sortKeys_[found] = key;
sortOrders_[found] = tempOrders[found];
System.arraycopy(temp, found, sortKeys_, found+1, temp.length-found);
System.arraycopy(tempOrders, found, sortOrders_, found+1, temp.length-found);
++currentSortKey_;
}
/**
* Helper method used to determine which extra keys, if any, need to be added for
* proper selection and sorting.
**/
private void fixUpKeys()
{
for (int i=0; ilistOffset and number
* will most likely not return the same ObjectDescriptions as the previous call.
* @param listOffset The offset in the list of objects (0-based). This value must be greater than or equal to 0 and
* less than the list length; or specify -1 to retrieve all of the objects.
* @param number The number of objects to retrieve out of the list, starting at the specified
* listOffset. This value must be greater than or equal to 0 and less than or equal
* to the list length. If the listOffset is -1, this parameter is ignored.
* @return The array of retrieved {@link com.ibm.as400.access.ObjectDescription ObjectDescription} objects.
* The length of this array may not necessarily be equal to number, depending upon the size
* of the list on the system, and the specified listOffset.
* @exception AS400Exception If the system returns an error message.
* @exception AS400SecurityException If a security or authority error occurs.
* @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 object does not exist on the system.
* @see com.ibm.as400.access.Job
* @see #close
* @see #load
**/
public synchronized ObjectDescription[] getObjects(int listOffset, int number) throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException
{
if (listOffset < -1)
{
throw new ExtendedIllegalArgumentException("listOffset", ExtendedIllegalArgumentException.RANGE_NOT_VALID);
}
if (number < 0 && listOffset != -1)
{
throw new ExtendedIllegalArgumentException("number", ExtendedIllegalArgumentException.RANGE_NOT_VALID);
}
if (handle_ == null) load(); // this sets the length_ variable
if (length_ == 0 || (number == 0 && listOffset != -1)) {
return new ObjectDescription[0];
}
if (listOffset == -1)
{
number = length_; // request entire list
listOffset = 0; // ... starting at beginning of list
}
else if (listOffset >= length_)
{
if (Trace.traceOn_)
Trace.log(Trace.WARNING, "Value of parameter 'listOffset' is beyond end of list:", listOffset + " (list length: " + length_ + ")");
return new ObjectDescription[0];
}
else if (listOffset + number > length_)
{
number = length_ - listOffset;
}
int ccsid = system_.getCcsid();
ConvTable conv = ConvTable.getTable(ccsid, null);
// Use recLen_ from load()'s list information to calculate receiver length needed @A2A
int len = number*recLen_; //@A2C
// The 'List information' structure from call to QGYGTLE.
// This value will be set by retrieveListEntries().
Object[] listInfoContainer = new Object[1]; // initialized to null
// Retrieve the entries in the list that was built by the most recent load().
byte[] data = ListUtilities.retrieveListEntries(system_, handle_, len, number, listOffset, listInfoContainer);
byte[] listInfo = (byte[])listInfoContainer[0];
if (listInfo == null || listInfo.length == 0) {
return new ObjectDescription[0];
// Shouldn't have to do this, but this API doesn't like certain empty libraries for some reason.
}
//int totalRecords = BinaryConverter.byteArrayToInt(listInfo, 0);
int recordsReturned = BinaryConverter.byteArrayToInt(listInfo, 4);
int recordLength = BinaryConverter.byteArrayToInt(listInfo, 12);
// Deleting following code, because there will not be a need to call a second @A2A
// time as we should always have enough room for the receiver now. @A2A
/* Start of deleted code which calls QGYGTLE a second time ----------------- @A2D
while (listOffset == -1 && totalRecords > recordsReturned)
{
len = len*(1+(totalRecords/(recordsReturned+1)));
if (Trace.traceOn_) Trace.log(Trace.DIAGNOSTIC, "Calling ObjectList QGYGTLE again with an updated length of "+len+".");
try
{
parms2[0].setOutputDataLength(len);
parms2[1].setInputData(BinaryConverter.intToByteArray(len));
}
catch (PropertyVetoException pve)
{
}
if (!pc2.run())
{
throw new AS400Exception(pc2.getMessageList());
}
listInfo = parms2[3].getOutputData();
totalRecords = BinaryConverter.byteArrayToInt(listInfo, 0);
recordsReturned = BinaryConverter.byteArrayToInt(listInfo, 4);
recordLength = BinaryConverter.byteArrayToInt(listInfo, 12);
}
End of deleted code which calls QGYGTLE a second time ----------------- @A2D */
ObjectDescription[] objects = new ObjectDescription[recordsReturned];
int offset = 0;
for (int i=0; i= COMBINATION_200)
{
objects[i].set(ObjectDescription.INFORMATION_STATUS, conv.byteArrayToString(keyData, 0, 1));
objects[i].set(ObjectDescription.EXTENDED_ATTRIBUTE, conv.byteArrayToString(keyData, 1, 10).trim());
objects[i].set(ObjectDescription.TEXT_DESCRIPTION, conv.byteArrayToString(keyData, 11, 10).trim());
objects[i].set(ObjectDescription.USER_DEFINED_ATTRIBUTE, conv.byteArrayToString(keyData, 61, 10).trim());
objects[i].set(ObjectDescription.ORDER_IN_LIBRARY_LIST, BinaryConverter.byteArrayToInt(keyData, 71));
}
if (key >= COMBINATION_300)
{
objects[i].set(ObjectDescription.OBJECT_ASP_NUMBER, BinaryConverter.byteArrayToInt(keyData, 80));
objects[i].set(ObjectDescription.OWNER, conv.byteArrayToString(keyData, 84, 10).trim());
objects[i].set(ObjectDescription.DOMAIN, conv.byteArrayToString(keyData, 94, 2));
byte[] timestamp = new byte[8];
System.arraycopy(keyData, 96, timestamp, 0, 8);
objects[i].set(ObjectDescription.CREATION_DATE, timestamp);
timestamp = new byte[8];
System.arraycopy(keyData, 104, timestamp, 0, 8);
objects[i].set(ObjectDescription.CHANGE_DATE, timestamp);
objects[i].set(ObjectDescription.STORAGE_STATUS, conv.byteArrayToString(keyData, 112, 10).trim());
objects[i].set(ObjectDescription.COMPRESSION, conv.byteArrayToString(keyData, 122, 1));
objects[i].set(ObjectDescription.ALLOW_CHANGE_BY_PROGRAM, keyData[123] == (byte)0xF1);
objects[i].set(ObjectDescription.CHANGED_BY_PROGRAM, keyData[124] == (byte)0xF1);
objects[i].set(ObjectDescription.AUDITING, conv.byteArrayToString(keyData, 125, 10).trim());
objects[i].set(ObjectDescription.DIGITALLY_SIGNED, keyData[135] == (byte)0xF1);
objects[i].set(ObjectDescription.DIGITALLY_SIGNED_TRUSTED, keyData[136] == (byte)0xF1);
objects[i].set(ObjectDescription.DIGITALLY_SIGNED_MULTIPLE, keyData[137] == (byte)0xF1);
objects[i].set(ObjectDescription.LIBRARY_ASP_NUMBER, BinaryConverter.byteArrayToInt(keyData, 140));
}
if (key >= COMBINATION_400)
{
}
System.out.println("Struct not supported: "+key);
}
*/
else
{
Trace.log(Trace.ERROR, "Unknown key type for key "+key+": "+type);
throw new InternalErrorException(InternalErrorException.SYNTAX_ERROR, key+": "+type,null);
}
fieldOffset += infoLength;
}
}
offset += recordLength;
}
return objects;
}
/**
* Returns the system.
* @return The system.
**/
public AS400 getSystem()
{
return system_;
}
/**
* Returns the object type used to filter this list. (For example: *LIB, *FILE, *OUTQ, etc)
* @return The object type.
**/
public String getType()
{
return objectType_;
}
/**
* Loads the list of objects on the system. This method informs the
* system to build a list of objects. This method blocks until the system returns
* the total number of objects it has compiled. A subsequent call to
* {@link #getObjects getObjects()} will retrieve the actual object information
* and attributes for each object in the list from the system.
* This method updates the list length.
*
* @exception AS400Exception If the system returns an error message.
* @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 object does not exist on the system.
* @exception ServerStartupException If the host server cannot be started.
* @see #getLength
* @see #close
**/
public synchronized void load() throws AS400Exception, AS400SecurityException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException
{
if (system_ == null) throw new ExtendedIllegalStateException("system", ExtendedIllegalStateException.PROPERTY_NOT_SET);
// Close the previous list
if (handle_ != null || handleToClose_ != null)
{
close();
}
// Generate text objects based on system CCSID
final int ccsid = system_.getCcsid();
ConvTable conv = ConvTable.getTable(ccsid, null);
AS400Text text10 = new AS400Text(10, ccsid, system_);
// Setup program parameters
ProgramParameter[] parms = new ProgramParameter[(aspDeviceName_ == null) ? 12 : 15]; // @550C changed to allow asp control
parms[0] = new ProgramParameter(1); // receiver variable
parms[1] = new ProgramParameter(BinaryConverter.intToByteArray(1)); // length of receiver variable
parms[2] = new ProgramParameter(ListUtilities.LIST_INFO_LENGTH); // list information
// Number of records to return.
// Special value '-1' indicates that "all records are built synchronously in the list".
parms[3] = new ProgramParameter(BinaryConverter.intToByteArray(-1));
fixUpKeys();
byte[] sortInfo = null;
int numSortKeys = currentSortKey_;
if (numSortKeys > 0)
{
sortInfo = new byte[4+numSortKeys*12];
BinaryConverter.intToByteArray(numSortKeys, sortInfo, 0);
int offset = 4;
for (int i=0; i
* {@link #ASP_SEARCH_TYPE_ASP ASP_SEARCH_TYPE_ASP} - Only the single ASP named will be searched.
* {@link #ASP_SEARCH_TYPE_ASPGRP ASP_SEARCH_TYPE_ASPGRP} - All ASPs in the auxiliary storage pool
* group named will be searched.
*
* The default value is {@link #ASP_SEARCH_TYPE_ASP ASP_SEARCH_TYPE_ASP}.
* @exception ExtendedIllegalArgumentException if an invalid search type is specified.
*/
public void setAspSearchType(String aspSearchType) throws ExtendedIllegalArgumentException{
if (aspSearchType == null) throw new NullPointerException("aspSearchType");
if (!aspSearchType.equals(ASP_SEARCH_TYPE_ASP) &&
!aspSearchType.equals(ASP_SEARCH_TYPE_ASPGRP))
{
throw new ExtendedIllegalArgumentException("aspSearchType", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID);
}
aspSearchType_ = aspSearchType;
}
/**
* Sets whether or not the object selection criteria are used to include
* objects in the list or to omit them from the list. The default is
* true, which is to include objects in the list with the specified criteria
* as added by {@link #addObjectSelectionCriteria addObjectSelectionCriteria()}.
* @param select true to include objects in the list that have the
* specified statuses, false to omit objects from the list that have the
* specified statuses.
* @see #addObjectSelectionCriteria
* @see #clearObjectSelectionCriteria
**/
public void setObjectSelection(boolean select)
{
statusSelection_ = select;
resetHandle();
}
/**
Closes the list on the system when this object is garbage collected.
**/
protected void finalize() throws Throwable
{
if (Trace.traceOn_) Trace.log(Trace.DIAGNOSTIC, "Finalize method for object list invoked.");
if (handle_ != null) try { close(); } catch (Throwable t) {}
super.finalize();
}
}