src.com.ibm.as400.access.Permission Maven / Gradle / Ivy
///////////////////////////////////////////////////////////////////////////////
//
// 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