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

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

There is a newer version: 20.0.8
Show newest version
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                              
//                                                                             
// Filename: Permission.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-2002 International Business Machines Corporation and     
// others. All rights reserved.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// @A1 - 10/04/2007 - Update commit() method to make two commit attempts for 
//                    permission changes that are pending.  This is necessary 
//                    because some changes are order dependent.  The commit()
//                    method allows for multiple changes to be pending at one
//                    time.  The specific problem encountered was for a DLO 
//                    object when going from Sensitivity/PublicAuth == None/*ALL
//                    to Sensitivity/PublicAuth == Private/*EXCLUDE.
//                    In this example, the PublicAuth must be changed before 
//                    the Sensitivity.  There are other examples where the 
//                    Sensitivity would need to be changed first.  A loop was
//                    added to the commit() method to accomodate either order.
// @A2 - 10/09/2007 - Update parseType() to process '/QSYS.LIB' correctly.  Add
//                    check to account for missing ending delimiter.
// @A3 - 02/12/2008 - Updates to process QSYS IASP objects correctly.
// @A4 - 03/01/2008 - Additional iasp updates
///////////////////////////////////////////////////////////////////////////////

package com.ibm.as400.access;

import java.beans.PropertyVetoException;
import java.beans.PropertyChangeListener;
import java.beans.PropertyChangeSupport;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.Serializable;
import java.io.UnsupportedEncodingException;
import java.util.Vector;
import java.util.Enumeration;


/**
 * Retrieves a user's authority to an object.
* To improve performance, the Permission object caches authority changes * until the commit() method is called. When commit()is called, * all changes up to that point are sent to the system.
* The permission of an object is a collection of many users' authority to that object, * and the UserPermission class is used to represent a user's authority to a object. * Because there are three kinds of objects on the system, three subclasses of * UserPermission are defined: *
    *
  • DLOPermission - Represents a user's authority to a Document Library Objects (DLO) * stored in QDLS. *
  • QSYSPermission - Represents a user's authority to the object which is contained in the system library * structure and stored in QSYS.LIB. *
  • RootPermission - Represents a user's authority to the object which is contained in the root directory * structure. This includes everything that is not in QSYS.LIB or QDLS. *
* Here is a simple example: *
 * AS400 as400 = new AS400();
 * Permission permission = new Permission(as400,"/QSYS.LIB/QJAVA.LIB");
 * permission.addAuthorizedUser("user1");
 * QSYSPermission userPermission = (QSYSPermission)permission.getUserPermission("user1");
 * userPermission.setObjectAuthority("*CHANGE");
 * permission.commit();
 * 
* @see UserPermission * @see DLOPermission * @see QSYSPermission * @see RootPermission **/ public class Permission implements Serializable { static final long serialVersionUID = 4L; /** * Constant indicating the object is a Document Library Objects (DLO) * stored in QDLS. * **/ public static final int TYPE_DLO = 0; /** * Constant indicating the object is contained in the system library * structure and stored in QSYS.LIB. * **/ public static final int TYPE_QSYS = 1; /** * Constant indicating that the object is contained in the root directory * structure. This includes everything that is not in QSYS.LIB or QDLS. * **/ public static final int TYPE_ROOT = 2; private AS400 as400_; private String authorizationList_; private String autListBackup_; private boolean autListChanged_; private String name_; private String owner_; private boolean ownerChanged_; // @B2a private boolean revokeOldAuthority_; // @B2a private boolean revokeOldGroupAuthority_; private boolean followSymbolicLinks_ = true; // @B6 The name supplied by the application for QSYS objects on IASPs is // "/aspName/QSYS.LIB/...". For QSYS objects the asp name will // be stripped. path_ will start with /QSYS.LIB, asp_ will hold // the asp name. Most pemission APIs dealing with QSYS objects // need a traditional QSYS name so path_ will be used as before. // One API and a couple commands, however, needs an IFS-style name. // For them the name will be put back together. Note the extra // processing is done only for QSYS objects. The extra // processing is not needed for QDLS objects since they cannot be on // ASPs. path_ will contain the entire path for root file system objects. // private String path_; private String asp_ = null; // @B6a private String primaryGroup_; private boolean primaryGroupChanged_; private boolean sensitivityChanged_; private int sensitivityLevel_; private int type_; private transient Vector userPermissionsBuffer_; private transient Vector userPermissions_; private transient Object userPermissionsLock_ = new Object(); private transient PermissionAccess access_; private transient PropertyChangeSupport changes_; /** * Constructs a Permission object. * @param file The IFSFile object. For example, The IFSFile object which represents the object "QSYS.LIB/FRED.LIB". * @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 system object does not exist. * @throws UnsupportedEncodingException * **/ public Permission(IFSFile file) throws AS400Exception, AS400SecurityException, ConnectionDroppedException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException, UnsupportedEncodingException { this(file.getSystem(),file.getPath(), false, true); // @B6c } // @B6a new method /** * Constructs a Permission object. *

* Use the independent auxiliary storage pool (IASP) parameter to indicate * if the path name can contain an IASP name. * If true, the name will be parsed as if the name starts with an IASP name. * If false, the name is treated as an ordinary path. For example, suppose * the path is "/myIASP/QSYS.LIB/MYLIB.LIB". If the IASP parameter is true * the object is treated as library "MYLIB" on IASP "myIASP". If the IASP * parameter is false the object is treated as object "MYLIB.LIB" in * directory "/myIASP/QSYS.LIB" in the root file system. Note the IASP * parameter is used only if the second component of the path is QSYS.LIB. * If the second component of the path is not QSYS.LIB, the parameter is ignored. * * @param file The IFSFile object. For example, The IFSFile object which represents the object "QSYS.LIB/FRED.LIB". * @param pathMayStartWithIASP True if the path may start with an * independent auxiliary storage pool (IASP) name; false otherwise. * @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 system object does not exist. * @throws UnsupportedEncodingException * **/ public Permission(IFSFile file, boolean pathMayStartWithIASP) throws AS400Exception, AS400SecurityException, ConnectionDroppedException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException, UnsupportedEncodingException { this(file.getSystem(),file.getPath(), pathMayStartWithIASP, true); } /** * Constructs a Permission object. *

* Use the independent auxiliary storage pool (IASP) parameter to indicate * if the path name can contain an IASP name. * If true, the name will be parsed as if the name starts with an IASP name. * If false, the name is treated as an ordinary path. For example, suppose * the path is "/myIASP/QSYS.LIB/MYLIB.LIB". If the IASP parameter is true * the object is treated as library "MYLIB" on IASP "myIASP". If the IASP * parameter is false the object is treated as object "MYLIB.LIB" in * directory "/myIASP/QSYS.LIB" in the root file system. Note the IASP * parameter is used only if the second component of the path is QSYS.LIB. * If the second component of the path is not QSYS.LIB, the parameter is ignored. * * @param file The IFSFile object. For example, The IFSFile object which represents the object "QSYS.LIB/FRED.LIB". * @param pathMayStartWithIASP True if the path may start with an * independent auxiliary storage pool (IASP) name; false otherwise. * @param followLinks Whether symbolic links are resolved. * The default value is true; that is, symbolic links are always resolved. * By default, if the IBM i object is a symbolic link, then the requested action * is performed on the object that is ultimately pointed to by the symbolic link, * rather than on the symbolic link itself. *
Note: This parameter is effective only for IBM i release V5R4 and higher. * For earlier releases, symbolic links are always resolved and this parameter is ignored. * @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 system object does not exist. * @throws UnsupportedEncodingException * **/ public Permission(IFSFile file, boolean pathMayStartWithIASP, boolean followLinks) throws AS400Exception, AS400SecurityException, ConnectionDroppedException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException, UnsupportedEncodingException { this(file.getSystem(),file.getPath(), pathMayStartWithIASP, followLinks); } /** * Constructs a Permission object. * @param as400 The system. * @param fileName The full path of the object. For example, "/QSYS.LIB/FRED.LIB". * @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 system object does not exist. * @throws UnsupportedEncodingException * **/ public Permission(AS400 as400, String fileName) throws AS400Exception, AS400SecurityException, ConnectionDroppedException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException, UnsupportedEncodingException { this(as400, fileName, false, true); // @B6c logic moved to next c'tor } /** * Constructs a Permission object. *

* Use the independent auxiliary storage pool (IASP) parameter to indicate * if the path name can contain an IASP name. * If true, the name will be parsed as if the name starts with an IASP name. * If false, the name is treated as an ordinary path. For example, suppose * the path is "/myIASP/QSYS.LIB/MYLIB.LIB". If the IASP parameter is true * the object is treated as library "MYLIB" on IASP "myIASP". If the IASP * parameter is false the object is treated as object "MYLIB.LIB" in * directory "/myIASP/QSYS.LIB" in the root file system. Note the IASP * parameter is used only if the second component of the path is QSYS.LIB. * If the second component of the path is not QSYS.LIB, the parameter is ignored. * * * @param as400 The system. * @param fileName The full path of the object. For example, "/QSYS.LIB/FRED.LIB". * @param pathMayStartWithIASP True if the path may start with an * independent auxiliary storage pool (IASP) name; false otherwise. * @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 system object does not exist. * @throws UnsupportedEncodingException * **/ public Permission(AS400 as400, String fileName, boolean pathMayStartWithIASP) throws AS400Exception, AS400SecurityException, ConnectionDroppedException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException, UnsupportedEncodingException { this(as400, fileName, pathMayStartWithIASP, true); } /** * Constructs a Permission object. *

* Use the independent auxiliary storage pool (IASP) parameter to indicate * if the path name can contain an IASP name. * If true, the name will be parsed as if the name starts with an IASP name. * If false, the name is treated as an ordinary path. For example, suppose * the path is "/myIASP/QSYS.LIB/MYLIB.LIB". If the IASP parameter is true * the object is treated as library "MYLIB" on IASP "myIASP". If the IASP * parameter is false the object is treated as object "MYLIB.LIB" in * directory "/myIASP/QSYS.LIB" in the root file system. Note the IASP * parameter is used only if the second component of the path is QSYS.LIB. * If the second component of the path is not QSYS.LIB, the parameter is ignored. * * * @param as400 The system. * @param fileName The full path of the object. For example, "/QSYS.LIB/FRED.LIB". * @param pathMayStartWithIASP True if the path may start with an * independent auxiliary storage pool (IASP) name; false otherwise. * @param followLinks Whether symbolic links are resolved. * The default value is true; that is, symbolic links are always resolved. * By default, if the IBM i object is a symbolic link, then the requested action * is performed on the object that is ultimately pointed to by the symbolic link, * rather than on the symbolic link itself. *
Note: This parameter is effective only for IBM i release V5R4 and higher. * For earlier releases, symbolic links are always resolved and this parameter is ignored. * @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 system object does not exist. * @throws UnsupportedEncodingException * **/ public Permission(AS400 as400, String fileName, boolean pathMayStartWithIASP, boolean followLinks) throws AS400Exception, AS400SecurityException, ConnectionDroppedException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException, UnsupportedEncodingException { if (as400 == null) throw new NullPointerException("system"); if (fileName == null) throw new NullPointerException("fileName"); as400_ = as400; int separator; path_ = fileName; separator = path_.lastIndexOf('/'); name_ = path_.substring(separator+1); type_ = parseType(path_, pathMayStartWithIASP); // @B6c // If 'followLinks' is false, check VRM, and if pre-V5R4 issue warning (and don't change flag). if (!followLinks && (as400_.getVRM() < 0x050400)) { if (Trace.traceOn_) { Trace.log(Trace.WARNING, "followLinks(false): Parameter is ignored because system is not V5R4 or higher."); } } else followSymbolicLinks_ = followLinks; switch(type_) { case TYPE_QSYS : access_ = new PermissionAccessQSYS(as400_); break; case TYPE_DLO : access_ = new PermissionAccessDLO(as400_); break; case TYPE_ROOT : default : access_ = new PermissionAccessRoot(as400_); break; } access_.setFollowSymbolicLinks(followSymbolicLinks_); Vector perms = null; try { // @B6 If the QSYS object is on an ASP, prepend the ASP name // to correctly fully qualify the path. // @A3 The ASP is already part of the path. (e.g. /iasp123/QSYS.LIB/xyz.lib) // String path = path_; // @B6a //@A3D // if (asp_ != null) // @B6a //@A3D // path = asp_ + path; // @B6a //@A3D perms = access_.getAuthority(path_); // @B6c changes_ = new PropertyChangeSupport(this); synchronized (userPermissionsLock_) { owner_ = (String)perms.elementAt(0); primaryGroup_ = (String)perms.elementAt(1); authorizationList_ = (String)perms.elementAt(2); //autListChanged_ = false; // @B2d sensitivityLevel_ = ((Integer)perms.elementAt(3)).intValue(); //sensitivityChanged_ = false; // @B2d userPermissionsBuffer_ = new Vector (); userPermissions_ = new Vector(); int count = perms.size(); for (int i=4;i=0;i--) { UserPermission userPermission = (UserPermission) userPermissionsBuffer_.elementAt(i); switch(userPermission.getCommitted()) { case UserPermission.COMMIT_FROM_AUTL : access_.setFromAuthorizationList(path_,userPermission.isFromAuthorizationList()); userPermission.setCommitted(UserPermission.COMMIT_NONE); break; case UserPermission.COMMIT_ADD : access_.addUser(path_,userPermission); userPermission.setCommitted(UserPermission.COMMIT_NONE); break; case UserPermission.COMMIT_CHANGE : access_.setAuthority(path_,userPermission); userPermission.setCommitted(UserPermission.COMMIT_NONE); break; case UserPermission.COMMIT_REMOVE : // Removed code which prepended asp since the asp is already in the path_ @A4D access_.removeUser(path_,userPermission.getUserID()); // @B6c //@A4C userPermission.setCommitted(UserPermission.COMMIT_NONE); userPermissionsBuffer_.removeElement(userPermission); break; case UserPermission.COMMIT_NONE : default : break; } } } } catch (PropertyVetoException e) { // should never happen Trace.log(Trace.ERROR, e); } } //end numberOfCommitAttempts loop @A1A changes_.firePropertyChange("permission",null,this); } /** * Returns the authorizations list of the object. * @return The authorizations list of the object. * @see #setAuthorizationList(String) * **/ public String getAuthorizationList() { return authorizationList_; } /** * Returns an enumeration of authorized users. * @return An enumeration of authorized users. * **/ public Enumeration getAuthorizedUsers() { synchronized (userPermissionsLock_) { int count = userPermissions_.size(); Vector names = new Vector(); for (int i=0;i *

  • 0 : This value does not apply to this object. *
  • 1 : (*NONE) The document has no sensitivity restrictions. *
  • 2 : (*PERSONAL) The document is intended for the user as an * individual. *
  • 3 : (*PRIVATE) The document contains information that should be * accessed only by the owner. This value cannot be * specified if the access code zero (0) is assigned to * the object. *
  • 4 : (*CONFIDENTIAL) The document contains information that should * be handled according to company procedures. * * @see #setSensitivityLevel * **/ public int getSensitivityLevel() { return sensitivityLevel_; } /** * Returns the system * @return The system instance. * **/ public AS400 getSystem() { return as400_; } /** * Returns the object type. * @return The object type. The possible values are: *
      *
    • TYPE_DLO - Indicating the object is a Document Library Objects (DLO) * stored in QDLS. *
    • TYPE_QSYS - Indicating the object is contained in the system library * structure and stored in QSYS.LIB. *
    • TYPE_ROOT - Indicating the object is contained in the root directory * structure. This includes everything that is not in QSYS.LIB or QDLS. *
    * **/ public int getType() { return type_; } /* Searches a user in specified vector. */ private int getUserIndex(String userProfileName,Vector vector) { int count = vector.size(); for (int i=0;i= 0) // if QSYS.LIB is someplace in the name // @B6a { // @B6a if (locationOfQSYS > 0) // if the name starts with QSYS.LIB // @B6a { // @B6a // QSYS.LIB is not the first component of the path. First, // @B6a // set "asp" to everything before /QSYS.LIB" except the // @B6a // first and last slash. // @B6a String asp = name.substring(1, locationOfQSYS); // @B6a // @B6a // does 'asp' contain a slash? If yes then it is not an ASP // @B6a // name, just the name of an object in the root file system. // @B6a // If asp does not contain a slash then it is an ASP name. // @B6a // Set class variable asp_ to "/aspName". Set class variable // @B6a // path_ to "/QSYS.LIB/...". // @B6a if (asp.indexOf('/') < 0) // @B6a { // @B6a asp_ = objectName.substring(0, locationOfQSYS); // @B6a // @A3 Leave the ASP in the path. (e.g. /iasp123/QSYS.LIB/xyz.lib) // path_ = objectName.substring(locationOfQSYS); // @B6a //@A3D return TYPE_QSYS; // @B6a } // @B6a else // @B6a ; // Don't do anything. QSYS.LIB is not the second // @B6a // component of the name so this object is not a QSYS // @B6a // object on an ASP, it is a normal root file // @B6a // system object. // @B6a } // @B6a else // The name starts with QSYS // @B6a return TYPE_QSYS; // @B6a } // @B6a // @B6a if (name.startsWith("/QDLS/")) // @B6a { // @B6a return TYPE_DLO; // @B6a } // @B6a // @B6a return TYPE_ROOT; // @B6a } // @B6a else // @B6a { // @B6a String name = objectName.toUpperCase(); // @A2A if(name.startsWith("/QSYS.LIB/") || name.equals("/QSYS.LIB")) // @A2C { return TYPE_QSYS; } // if(objectName.toUpperCase().startsWith("/QDLS/") || objectName.toUpperCase().equals("/QDLS")) // @1JUC check to see if it is the qdls root folder if(name.startsWith("/QDLS/") || name.equals("/QDLS")) // @A2C @1JUC check to see if it is the qdls root folder { return TYPE_DLO; } return TYPE_ROOT; } // @B6a } /** * Serialization support. * @exception ClassNotFoundException Thrown when an application tries to load in a class through its string name, * but no definition for the class with the specifed name could be found. * @exception IOException If an error occurs while communicating with the system. * **/ private void readObject(ObjectInputStream s) throws ClassNotFoundException, IOException { int size; s.defaultReadObject(); switch(type_) { case TYPE_QSYS : access_ = new PermissionAccessQSYS(as400_); break; case TYPE_DLO : access_ = new PermissionAccessDLO(as400_); break; case TYPE_ROOT : default : access_ = new PermissionAccessRoot(as400_); break; } access_.setFollowSymbolicLinks(followSymbolicLinks_); userPermissionsLock_ = new Object(); userPermissionsBuffer_ = new Vector (); userPermissions_ = new Vector(); size = ((Integer)s.readObject()).intValue(); for (int i=0;i
         * Permission permisson = new Permisson(new AS400(),"/QSYS.LIB/FRED.LIB";
         * permission.setAuthorizationList("testautl");
         * System.out.println("The authorization list of fred.lib is " + permissin.geAuthorizationList();
         * permission.setAuthorizationList("*NONE");
         * System.out.println("The authorization list of fred.lib is " + permissin.geAuthorizationList();
         * 
    * @param autList The authorizations list of the object. * **/ public synchronized void setAuthorizationList(String autList) { if (autList == null) throw new NullPointerException("autList"); if (autList.trim().equalsIgnoreCase(authorizationList_)) return; if (autListChanged_== false) autListBackup_ = authorizationList_; authorizationList_ = autList.trim().toUpperCase(); autListChanged_ = true; } // @B2a /** * Sets the owner of the object. * @param owner The owner of the object. * @param revokeOldAuthority Specifies whether the authorities for the current * owner are revoked when ownership is transferred to the new owner. * * @see #getOwner **/ public synchronized void setOwner(String owner, boolean revokeOldAuthority) { if (owner == null) throw new NullPointerException("owner"); owner_ = owner; revokeOldAuthority_ = revokeOldAuthority; ownerChanged_ = true; } /** * Sets the primary group of the object. * @param primaryGroup The primary group of the object. * @param revokeOldAuthority Specifies whether the authorities for the current * primary group are revoked when the primary group is changed to the new value. * **/ public void setPrimaryGroup(String primaryGroup, boolean revokeOldAuthority) { if (primaryGroup == null) throw new NullPointerException("primaryGroup"); primaryGroup_ = primaryGroup; revokeOldGroupAuthority_ = revokeOldAuthority; primaryGroupChanged_ = true; } /** * Sets the sensitivity level of the object. * @param sensitivityLevel The sensitivity level of the object. The * possible values : *
      *
    • 0 : This value does not apply to this object. *
    • 1 : (*NONE) The document has no sensitivity restrictions. *
    • 2 : (*PERSONAL) The document is intended for the user as an * individual. *
    • 3 : (*PRIVATE) The document contains information that should be * accessed only by the owner. This value cannot be * specified if the access code zero (0) is assigned to * the object. *
    • 4 : (*CONFIDENTIAL) The document contains information that should * be handled according to company procedures. *
    * * @see #getSensitivityLevel **/ public synchronized void setSensitivityLevel(int sensitivityLevel) { if (sensitivityLevel < 0 || sensitivityLevel > 4) { throw new ExtendedIllegalArgumentException("sensitivityLevel ("+sensitivityLevel+")", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID ); } sensitivityLevel_ = sensitivityLevel; sensitivityChanged_ = true; } /** * Sets the system where system value is retrieved. * * @param system The system object. * @see #getSystem * @deprecated This method is of little (or no) known usefulness. If you require this method, please notify the Toolbox support team. **/ public synchronized void setSystem(AS400 system) { if (system == null) throw new NullPointerException("system"); if (as400_ == null) //$B1C as400_ = system; //$B1C else //$B1C { if (as400_.isConnected()) { throw new ExtendedIllegalStateException("system", ExtendedIllegalStateException.PROPERTY_NOT_CHANGED); } if (as400_.equals(system)==true) return; } switch(type_) { case TYPE_QSYS : access_ = new PermissionAccessQSYS(as400_); break; case TYPE_DLO : access_ = new PermissionAccessDLO(as400_); break; case TYPE_ROOT : default : access_ = new PermissionAccessRoot(as400_); break; } access_.setFollowSymbolicLinks(followSymbolicLinks_); // Assume that, since we're (re)connecting to the same system we were originally connected to, that none of the permissions information needs to be re-retrieved. } /** * Serialization support. * @exception IOException If an error occurs while communicating with the system. * **/ private void writeObject(ObjectOutputStream s) throws IOException { s.defaultWriteObject(); synchronized (userPermissionsLock_) { s.writeObject(new Integer(userPermissionsBuffer_.size())); for (int i=0;i




  • © 2015 - 2025 Weber Informatics LLC | Privacy Policy