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

com.ibm.as400.access.IFSFile Maven / Gradle / Ivy

The newest version!
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// JTOpen (IBM Toolbox for Java - OSS version)                              
//                                                                             
// Filename: IFSFile.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.                                                
//                                                                             
///////////////////////////////////////////////////////////////////////////////
//                                                                             
// @D5 - 06/18/2007 - Changes to enumerateFiles() processing to better handle
//                    when objects are filtered from the list returned by the 
//                    IFS File Server.
// @D7 - 07/25/2007 - Add allowSortedRequest parameter to listFiles0() method 
//                    to resolve problem of issuing PWFS List Attributes request
//                    with both "Sort" indication and "RestartByID" 
//                    which is documented to be an invalid combination.
// @D8 - 04/03/2008 - Modify clearCachedAttributes() to also call 
//                    impl.clearCachedAttributes()
// @SA - 11/22/2016 - Add getASP() and getFileSystemType()
// @SC - 01/04/2017 - Fix getCCSID() and getOwnerName()
//                                                                             
///////////////////////////////////////////////////////////////////////////////
package com.ibm.as400.access;

import java.beans.PropertyChangeSupport;
import java.beans.PropertyChangeListener;
import java.beans.PropertyVetoException;
import java.beans.VetoableChangeSupport;
import java.beans.VetoableChangeListener;
import java.io.InterruptedIOException;
import java.io.File;
import java.io.IOException;
import java.io.Serializable;
import java.io.UnsupportedEncodingException; //@A6A
import java.net.UnknownHostException;
import java.util.Enumeration;
import java.util.Vector;
import java.util.StringTokenizer;            //@D4A


/**
  * Represents an object in the IBM i integrated file system.
  * As in {@link java.io.File java.io.File}, IFSFile is designed to work
  * with the object as a whole.  For example, use IFSFile
  * to delete or rename a file, to access the
  * file's attributes (is the object a file or a directory,
  * when was the file last changed, is the file hidden, etc.),
  * or to list the contents of a directory.
  * Use {@link IFSFileInputStream IFSFileInputStream} or
  * {@link IFSRandomAccessFile IFSRandomAccessFile} to read
  * data from the file, and {@link IFSFileOutputStream IFSFileOutputStream} or
  * {@link IFSRandomAccessFile IFSRandomAccessFile}
  * to write data to the file.
  * Note that for invalid symbolic links, both {@link #isFile() isFile} and
  * {@link #isDirectory() isDirectory} will return false.
  *
  * 

* IFSFile objects are capable of generating file events that call the * following {@link FileListener FileListener} methods: {@link FileListener#fileDeleted fileDeleted()} and {@link FileListener#fileModified fileModified()}. *

* The following example demonstrates the use of IFSFile: * *

  * // Work with /Dir/File.txt on the system named MYSYSTEM.
  * AS400 as400 = new AS400("MYSYSTEM");
  * IFSFile file = new IFSFile(as400, "/Dir/File.txt");
  *
  * // Determine the parent directory of the file.
  * String directory = file.getParent();
  *
  * // Determine the name of the file.
  * String name = file.getName();
  *
  * // Determine the file size.
  * long length = file.length();
  *
  * // Determine when the file was last modified.
  * Date date = new Date(file.lastModified());
  *
  * // Delete the file.
  * if (file.delete() == false)
  * {
  *   // Display the error code.
  *   System.out.println("Unable to delete file.");
  * }
  * 
* *

Note: Because of a host server restriction, you cannot use this class to * access files in QTEMP.LIB. * *

Note: Support for "large files" (files larger than 2 gigabytes) was added * to the File Server in IBM i V6R1, and was not PTF'd back to prior IBM i versions. * The Toolbox's IFS classes rely on the File Server to access and * manipulate files in the integrated file system. * *

* Note on the use of IFS classes when accessing QSYS files: *
The IFS classes are of limited usefulness when accessing formatted * file objects under QSYS, such as physical files and save files. * The IFS classes perform their work via datastream * requests that are sent to the "File Server" job on the IBM i system. * The File Server has its own idea of what is a "file" versus a "directory". * In the case of a QSYS file object that contains records and/or members, * the File Server tends to view such an object as a composite "directory" * rather than a flat data "file" (since the File Server wouldn't be free to just * start reading/writing bytes of data from/to the file at whatever offset, * without ending up with meaningless or corrupted data). * The File Server has no awareness of, or respect for, file record structure. * When accessing QSYS file objects, consider the use of other classes such as * {@link SequentialFile SequentialFile}, {@link KeyedFile KeyedFile}, and * {@link SaveFile SaveFile}. * * @see FileEvent * @see #addFileListener(FileListener) * @see #removeFileListener(FileListener) * @see IFSJavaFile * @see IFSRandomAccessFile * @see IFSFileInputStream * @see IFSFileOutputStream * @see IFSFileReader * @see IFSFileWriter **/ public class IFSFile implements Serializable, Comparable { static final long serialVersionUID = 4L; /** The integrated file system path separator string used to separate paths in a path list. **/ public final static String pathSeparator = ";"; /** The integrated file system path separator character used to separate paths in a path list. **/ public final static char pathSeparatorChar = ';'; /** The integrated file system directory separator string used to separate directory/file components in a path. **/ public final static String separator = "/"; /** The integrated file system directory separator character used to separate directory/file components in a path. **/ public final static char separatorChar = '/'; private final static String DOT = "."; // @D4A private final static String DOTDOT = "..";// @D4A // Constants used by QlgChmod and QlgAccess. Defined in system header file "stat.h". // Note that these values are expressed in octal. final static int ACCESS_EXECUTE = 001; final static int ACCESS_WRITE = 002; final static int ACCESS_READ = 004; /** Value for indicating that "POSIX" pattern-matching is used by the various list() and listFiles() methods.
Using POSIX semantics, all files are listed that match the pattern and do not begin with a period (unless the pattern begins with a period). In that case, names beginning with a period are also listed. Note that when no pattern is specified, the default pattern is "*".
Note: In OS/400 V5R1 and earlier, all files that match the pattern are listed, including those that begin with a period. **/ public final static int PATTERN_POSIX = 0; final static int PATTERN_DEFAULT = PATTERN_POSIX; // for use within package /** Value for indicating that "POSIX-all" pattern-matching is used by the various list() and listFiles() methods.

Using POSIX semantics, all files are listed that match the pattern, including those that begin with a period. **/ public final static int PATTERN_POSIX_ALL = 1; /** Value for indicating that "OS/2" pattern-matching is used by the various list() and listFiles() methods. Using DOS semantics, all files are listed that match the pattern. **/ public final static int PATTERN_OS2 = 2; private final static String SECURITY_EXCEPTION = "Security exception."; transient private PropertyChangeSupport changes_; transient private VetoableChangeSupport vetos_; transient private Vector fileListeners_; transient private IFSFileImpl impl_; private AS400 system_; private String path_ = ""; // Note: This is never allowed to be null. private Permission permission_; private String subType_; transient private IFSCachedAttributes cachedAttributes_; private boolean isDirectory_; private boolean isFile_; private boolean isSymbolicLink_; private int patternMatching_; // type of pattern matching to use when listing files private boolean sortLists_; // whether file-lists are returned from the File Server in sorted order // Several pieces of member data set by listFiles0() for IFSFileEnumeration // to indicate the number of objects returned from the IFS File Server and // also the restartName and restartID info of the last object returned. private int listFiles0LastNumObjsReturned_; private String listFiles0LastRestartName_=null; private byte[] listFiles0LastRestartID_; /** * Constructs an IFSFile object. It creates a default IFSFile instance. **/ public IFSFile() { initializeTransient(); } /** * Constructs an IFSFile object. It creates an IFSFile instance that represents the integrated file system object on * system that has a path name of directory, that is followed by the separator character and * name. * * @param system The system that contains the file. * @param directory The directory. * @param name The file name. **/ public IFSFile(AS400 system, IFSFile directory, String name) { if (system == null) throw new NullPointerException("system"); if (directory == null) throw new NullPointerException("directory"); else if (name == null) throw new NullPointerException("name"); initialize(system, directory.getAbsolutePath(), name); } /** * Constructs an IFSFile object. It creates an IFSFile instance that represents the integrated file system object on * system that has a path name of path. * * @param system The system that contains the file. * @param path The absolute path name of the file. **/ public IFSFile(AS400 system, String path) { if (system == null) throw new NullPointerException("system"); else if (path == null) throw new NullPointerException("path"); initialize(system, null, path); } /** * Constructs an IFSFile object. It creates an IFSFile instance that represents the integrated file system object on * system that has a path name is of directory, followed by the separator character and name. * * @param system The system that contains the file. * @param directory The directory path name. * @param name The file name. **/ public IFSFile(AS400 system, String directory, String name) { if (system == null) throw new NullPointerException("system"); else if (directory == null) throw new NullPointerException("directory"); else if (name == null) throw new NullPointerException("name"); initialize(system, directory, name); } /** * Creates a new IFSFile instance from a parent abstract pathname and a child pathname string. *

* The directory argument cannot be null. The constructed IFSFile instance uses the following settings taken * from directory: *

    *
  • system *
  • path *
* The resulting file name is taken from the path name of directory, followed by the separator character, * followed by name. * * @param directory The directory where the IFSFile is or will be stored. * @param name The name of the IFSFile object. **/ public IFSFile(IFSFile directory, String name) { if (directory == null) throw new NullPointerException("directory"); initialize(directory.getSystem(), directory.getPath(), name); } /** * Constructs an IFSFile object. It creates an IFSFile instance that represents the integrated file system object on * system that has a path name of directory, that is followed by the separator character and * name. * * @param system The system that contains the file. * @param directory The directory. * @param name The file name. **/ public IFSFile(AS400 system, IFSJavaFile directory, String name) { if (system == null) throw new NullPointerException("system"); else if (directory == null) throw new NullPointerException("directory"); else if (name == null) throw new NullPointerException("name"); initialize(system, directory.getAbsolutePath().replace(File.separatorChar, separatorChar), name); } private void initialize(AS400 system, String directory, String name) { initializeTransient(); path_ = normalizePath(directory, name); system_ = system; } /** * INTERNAL USE ONLY - SUBJECT TO CHANGE * * Constructs an IFSFile object. It creates an IFSFile instance that represents the integrated file system object on * system that has a path name of directory, that is followed by the separator character and * name. {@link #isDirectory() isDirectory} and {@link #isFile() isFile} will both return false for invalid * symbolic links. * * @param system The system that contains the file. * @param attributes The attributes of the file. **/ IFSFile(AS400 system, IFSCachedAttributes attributes) { // Validate arguments. if (attributes == null) throw new NullPointerException("attributes"); initialize(system, attributes.getParent(), attributes.getName()); // Cache file attributes. cachedAttributes_ = attributes; //isDirectory and isFile can both be false if the object is an invalid symbolic link. isDirectory_ = attributes.getIsDirectory(); isFile_ = attributes.getIsFile(); isSymbolicLink_ = attributes.isSymbolicLink(); } /** * Adds a file listener to receive file events from this IFSFile. * * @param listener The file listener. **/ public void addFileListener(FileListener listener) { if (listener == null) throw new NullPointerException("listener"); fileListeners_.addElement(listener); } /** * Adds a property change listener. * * @param listener The property change listener to add. **/ public void addPropertyChangeListener(PropertyChangeListener listener) { if (listener == null) throw new NullPointerException("listener"); changes_.addPropertyChangeListener(listener); } /** * Adds a vetoable change listener. * * @param listener The vetoable change listener to add. **/ public void addVetoableChangeListener(VetoableChangeListener listener) { if (listener == null) throw new NullPointerException("listener"); vetos_.addVetoableChangeListener(listener); } /** * Determines if the application is allowed to execute the integrated file system object represented by this object. * This method is supported for IBM i V5R1 and higher. For older releases, it simply returns false. If the user * profile has *ALLOBJ special authority (and system is V5R1 or higher), this method always returns true. * * @return true if the object exists and is executable by the application; false otherwise. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. **/ public boolean canExecute() throws IOException { try { // Note: The called API (QlgAccess) is supported for V5R1 and higher. if (impl_ == null) chooseImpl(); return impl_.canExecute(); } catch (AS400SecurityException e) { // If we got the exception simply because we don't have "execute" access, ignore it. if (e.getReturnCode() == AS400SecurityException.DIRECTORY_ENTRY_ACCESS_DENIED) return false; // some other return code Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /** * Determines if the application can read from the integrated file system object represented by this object. Note that * IBM i directories are never readable; only files can be readable. * * @return true if the object exists and is readable by the application; false otherwise. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. **/ public boolean canRead() throws IOException { try { if (impl_ == null) chooseImpl(); return impl_.canRead(); } catch (AS400SecurityException e) { // If we got the exception simply because we don't have "read" access, ignore it. if (e.getReturnCode() == AS400SecurityException.DIRECTORY_ENTRY_ACCESS_DENIED) return false; // some other return code Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /** * Determines if the application can write to the integrated file system object represented by this object. Note that * IBM i directories are never writable; only files can be writable. * * @return true if the object exists and is writeable by the application; false otherwise. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public boolean canWrite() throws IOException { try { if (impl_ == null) chooseImpl(); return impl_.canWrite(); } catch (AS400SecurityException e) { // If we got the exception simply because we don't have "write" access, ignore it. if (e.getReturnCode() == AS400SecurityException.DIRECTORY_ENTRY_ACCESS_DENIED) return false; // some other return code Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * Chooses the appropriate implementation. */ void chooseImpl() throws IOException, AS400SecurityException { if (impl_ != null) return; // Ensure that the system has been set. if (system_ == null) throw new ExtendedIllegalStateException("system", ExtendedIllegalStateException.PROPERTY_NOT_SET); // Ensure that the path name is set. if (path_.length() == 0) throw new ExtendedIllegalStateException("path", ExtendedIllegalStateException.PROPERTY_NOT_SET); impl_ = (IFSFileImpl) system_.loadImpl2("com.ibm.as400.access.IFSFileImplRemote", "com.ibm.as400.access.IFSFileImplProxy"); system_.connectService(AS400.FILE); impl_.setSystem(system_.getImpl()); impl_.setPath(path_); } /** * Clear the cached attributes. This is needed when cached attributes need to be refreshed. * * @see #listFiles **/ public void clearCachedAttributes() { cachedAttributes_ = null; if (impl_ != null) impl_.clearCachedAttributes(); } /** * Compares the path of this IFSFile with an Object's path. If the other object is not an IFSFile or * java.io.File, this method throws a ClassCastException, since IFSFile is comparable only to IFSFile and * java.io.File. * *

* Note:
* The comparison is case sensitive. * * @param obj The Object to be compared. * * @return 0 if this IFSFile path equals the argument's path; a value less than 0 if this * IFSFile path is less than the argument's path; and a value greater than 0 if this IFSFile path * is greater than the argument's path. * **/ @Override public int compareTo(Object obj) { if (obj instanceof IFSFile) return getPath().compareTo(((IFSFile)obj).getPath()); return getPath().compareTo(((java.io.File)obj).getPath()); } /** * Copies this file or directory to the specified file or directory on the system. If the destination file already * exists, it is overwritten. If this IFSFile represents a directory: *

    *
  • The destination directory must be nonexistent, otherwise an exception is thrown. *
  • The entire directory (including all of its contents and subdirectories) is copied. *
* * @param path The destination path to copy this IFSFile to.
* If the system is V5R2 or earlier: If the current object is a file (rather than a directory), the * destination path must also specify a file (rather than a directory), otherwise the copy may fail. * @return true if the copy succeeded (or at least one file of a source directory's contents was copied); false * otherwise. * @throws IOException If an error occurs while communicating with the system. * @throws AS400SecurityException If a security or authority error occurs. * @throws ObjectAlreadyExistsException If the object already exists. **/ public boolean copyTo(String path) throws IOException, AS400SecurityException, ObjectAlreadyExistsException { return copyTo(path, true); } /** * INTERNAL USE ONLY - SUBJECT TO CHANGE * * Copies this file or directory to the specified file or directory * on the system. * If the destination file already exists: *
    *
  • If replace is true, the destination file is overwritten. *
  • If replace is false, an exception is thrown. *
* If this IFSFile represents a directory: *
    *
  • The destination directory must be nonexistent, otherwise an exception is thrown. *
  • The entire directory (including all of its contents and subdirectories) is copied. *
* @param path The destination path to copy this IFSFile to. *
Note: If the system is V5R2 or earlier: If the current object is a file (rather than a directory), the destination path must also specify a file (rather than a directory), otherwise the copy may fail. * @param replace true to overwrite the destination if it already exists, false otherwise. *
Note: If the system is V5R2 or earlier, this parameter has no effect; that is, the destination is always overwritten. * @return true if the copy succeeded (or at least one file of a source * directory's contents was copied); false otherwise. **/ // Note: Don't make this method public for now. The limitations of the 'replace' // option are too complex, in terms of what the File Server can do for us. // Wait until we have better support from the File Server. boolean copyTo(String path, boolean replace) throws IOException, AS400SecurityException, ObjectAlreadyExistsException { if (path == null) throw new NullPointerException("path"); if (impl_ == null) chooseImpl(); return impl_.copyTo(path, replace); } /** * Determines the time that the integrated file system object represented by this object was created. * * @return The time (measured in milliseconds since 01/01/1970 00:00:00 GMT) that the integrated file system object * was created, or 0L if the object does not exist or is not accessible. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public long created() throws IOException { try { if (cachedAttributes_ != null) return cachedAttributes_.getCreationDate(); if (impl_ == null) chooseImpl(); return impl_.created(); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /** * Atomically creates a new, empty file named by this abstract pathname if and only if a file with this name does not * yet exist. The check for the existence of the file and the creation of the file if it does not exist are a single * operation that is atomic with respect to all other filesystem activities that might affect the file. If the file * already exists, its data are left intact. * * @return true if the named file does not exist and was successfully created; false if the named * file already exists. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * @exception IOException If the user is not authorized to create the file. **/ public boolean createNewFile() throws IOException { int returnCode = IFSReturnCodeRep.FILE_NOT_FOUND; try { if (impl_ == null) chooseImpl(); returnCode = impl_.createNewFile(); switch (returnCode) { case IFSReturnCodeRep.SUCCESS: break; case IFSReturnCodeRep.DUPLICATE_DIR_ENTRY_NAME: // file already exists if (Trace.traceOn_) Trace.log(Trace.DIAGNOSTIC, "File already exists: " + path_); break; case IFSReturnCodeRep.PATH_NOT_FOUND: // directory doesn't exist if (Trace.traceOn_) Trace.log(Trace.DIAGNOSTIC, "Path not found: " + path_); break; default: Trace.log(Trace.ERROR, "Return code " + returnCode + " from createNewFile()."); throw new ExtendedIOException(returnCode); // Note: The return codes in IFSReturnCodeRep are replicated in ExtendedIOException. } } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } return (returnCode == IFSReturnCodeRep.SUCCESS); } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * internal delete that returns a return code status indicator */ int delete0() throws IOException, AS400SecurityException { if (impl_ == null) chooseImpl(); int rc = impl_.delete(); // Verify that the request was successful. if (rc == IFSReturnCodeRep.SUCCESS) { // Fire the file deleted event. if (fileListeners_.size() != 0) { FileEvent event = new FileEvent(this, FileEvent.FILE_DELETED); synchronized (fileListeners_) { Enumeration e = fileListeners_.elements(); while (e.hasMoreElements()) { FileListener listener = (FileListener) e.nextElement(); listener.fileDeleted(event); } } } // Clear any cached attributes. cachedAttributes_ = null; } return rc; } /** * Deletes the integrated file system object represented by this object. * * @return true if the file system object is successfully deleted; false otherwise. Returns false if the file system * object did not exist prior to the delete() or is not accessible. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public boolean delete() throws IOException { // If it looks like it's in QSYS, then the stream file operation to the host server will likely not work. For // files and members, though, we can handle specially here. if(isInQsys()) { AS400File tmpPF = null; ObjectDescription objectDescription = new ObjectDescription(system_, path_.replaceAll("//+", "/")); try { String type = objectDescription.getType(); switch (type) { case "FILE": //note: includes *SAVF objects tmpPF = new SequentialFile(system_, objectDescription.getPath()); tmpPF.delete(); return true; case "MBR": tmpPF = new SequentialFile(system_, objectDescription.getPath()); tmpPF.deleteMember(); return true; } } catch (AS400SecurityException | InterruptedException | IOException | ErrorCompletingRequestException e) { Trace.log(Trace.WARNING, "Unable to delete QSYS file using classic techniques. Will try host server stream file operations."+path_, e); } finally { if(null != tmpPF) { try { tmpPF.close(); } catch (AS400Exception | AS400SecurityException | InterruptedException | IOException e) { Trace.log(Trace.ERROR, "Unexpected error closing file "+path_, e); } } } } int returnCode = IFSReturnCodeRep.FILE_NOT_FOUND; try { returnCode = delete0(); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } return (returnCode == IFSReturnCodeRep.SUCCESS); } /** * Lists the integrated file system objects in the directory represented by this object that satisfy filter. * The returned Enumeration contains an IFSFile object for each file or directory in the list. The list is loaded * incrementally, which will improve initial response time for large lists. * * @param filter A file object filter. * @param pattern The pattern that all filenames must match. Acceptable characters are wildcards (*) and question * marks (?). * * @return An Enumeration of IFSFile objects which represent the contents of the directory that satisfy the filter and * pattern. This Enumeration does not include the current directory or the parent directory. If this object * does not represent a directory, this object represents an empty directory, or the filter or pattern does * not match any files, then an empty Enumeration is returned. The IFSFile object passed to the filter object * has cached file attribute information. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system, or the directory is * not accessible. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. **/ public Enumeration enumerateFiles(IFSFileFilter filter, String pattern) throws IOException { // Validate arguments. Note that we tolerate a null-valued 'filter'. if (pattern == null) throw new NullPointerException("pattern"); try { return new IFSFileEnumeration(this, filter, pattern); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /** * Lists the integrated file system objects in the directory represented by this object. The returned Enumeration * contains an IFSFile object for each file or directory in the list. The list is loaded incrementally, which will * improve initial response time for large lists. * * @param pattern The pattern that all filenames must match. Acceptable characters are wildcards (*) and question * marks (?). * * @return An Enumeration of IFSFile objects which represent the contents of the directory. This Enumeration does not * include the current directory or the parent directory. If this object does not represent a directory, this * object represents an empty directory, or the pattern does not match any files, then an empty Enumeration is * returned. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system, or the directory is * not accessible. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. **/ public Enumeration enumerateFiles(String pattern) throws IOException { // Validate arguments. Note that we tolerate a null-valued 'filter'. if (pattern == null) throw new NullPointerException("pattern"); try { return new IFSFileEnumeration(this, null, pattern); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /** * Lists the integrated file system objects in the directory represented by this object that satisfy filter. * The returned Enumeration contains an IFSFile object for each file or directory in the list. The list is loaded * incrementally, which will improve initial response time for large lists. * * @param filter A file object filter. * * @return An Enumeration of IFSFile objects which represent the contents of the directory. This Enumeration does not * include the current directory or the parent directory. If this object does not represent a directory, this * object represents an empty directory, or the filter does not match any files, then an empty Enumeration is * returned. The IFSFile object passed to the filter object has cached file attribute information. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system, or the directory is * not accessible. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. **/ public Enumeration enumerateFiles(IFSFileFilter filter) throws IOException { try { return new IFSFileEnumeration(this, filter, "*"); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /** * Lists the integrated file system objects in the directory represented by this object. The returned Enumeration * contains an IFSFile object for each file or directory in the list. The list is loaded incrementally, which will * improve initial response time for large lists. * * @return An Enumeration of IFSFile objects which represent the contents of the directory. This Enumeration does not * include the current directory or the parent directory. If this object does not represent a directory, this * object represents an empty directory, or the filter or pattern does not match any files, then an empty * Enumeration is returned. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system, or the directory is * not accessible. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. **/ public Enumeration enumerateFiles() throws IOException { try { return new IFSFileEnumeration(this, null, "*"); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /** * Determines if two IFSFile objects are equal. * * @param obj The object with which to compare. * @return true if the path name and system names of the objects are equal; false otherwise. **/ @Override public boolean equals(Object obj) { if (obj == null || !(obj instanceof IFSFile)) return false; // Determine the system name and path name. IFSFile target = (IFSFile) obj; String targetPathName = target.getPath(); AS400 targetSystem = target.getSystem(); String targetSystemName = null; if (targetSystem != null) targetSystemName = targetSystem.getSystemName(); boolean result = true; // It's OK for *neither* or *both* objects have system==null. if (system_ == null) result = (targetSystemName == null); else result = system_.getSystemName().equals(targetSystemName); result = result && (path_.equals(targetPathName)); return result; } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * internal exists that returns a return code status indicator */ int exists0() throws IOException, AS400SecurityException { // Assume the argument has been validated as non-null. if (impl_ == null) chooseImpl(); return impl_.exists(); } /** * Determines if the integrated file system object represented by this object exists. * * @return true if the object exists; false if the object does not exist or is not accessible. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public boolean exists() throws IOException { int returnCode = IFSReturnCodeRep.FILE_NOT_FOUND; try { returnCode = exists0(); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } return (returnCode == IFSReturnCodeRep.SUCCESS); } /** * Returns the path name of the integrated file system object represented by this object. This is the full path * starting at the root directory. * * @return The absolute path name of this integrated file system object. **/ public String getAbsolutePath() { return path_; } /** * Returns the canonical pathname string of the integrated file system object represented by this object. This is the * full path starting at the root directory. This typically involves removing redundant names such as "." and ".." * from the pathname. Symbolic links are not resolved. * * @return The canonical path name of this integrated file system object. **/ public String getCanonicalPath() { // Numerous changes added to remove DOT, DOTDOT, and multiple // separator characters. Previously, this method simply returned path_ StringBuilder pathBuffer = new StringBuilder(""); String pathElem; if (Trace.isTraceOn()) Trace.log(Trace.DIAGNOSTIC, " path_='"+path_+"'"); StringTokenizer st = new StringTokenizer(path_, separator); // Process each path element. while (st.hasMoreTokens()) { pathElem = st.nextToken(); if (Trace.isTraceOn()) Trace.log(Trace.DIAGNOSTIC, " pathElem='"+pathElem+"'"); if (pathElem.length() == 0) { // pathElem is empty... or is only the separator // Nothing to add to pathBuffer... } else if (pathElem.equals(DOT)) { // Remove the "." from the path... copy nothing to pathBuffer. } else if (pathElem.equals(DOTDOT)) { // Remove last element of current canPath int lastSepIndex = pathBuffer.lastIndexOf(separator); if (lastSepIndex == -1) { // Can get here if too many DOT-DOTs which would result // in trying to preceed the root directory.... // Ignore this path element } else { // This will remove the last element of canPath //(e.g. "/abc/xyz" will become "/abc") pathBuffer.delete(lastSepIndex, pathBuffer.length()); } } else { // Normal path element... so append it pathBuffer.append(separator); pathBuffer.append(pathElem); } } if (Trace.isTraceOn()) Trace.log(Trace.DIAGNOSTIC, " pathBuffer.toString()='"+pathBuffer.toString()+"'"); // Return path. Note that 0-length path is possible if path_ contains nothing but DOTs and DOTDOTs return (pathBuffer.length() == 0) ? separator : pathBuffer.toString(); } /** * Returns the file's data CCSID. All files in the system's integrated file system are tagged with a CCSID. This * method returns the value of that tag. If the file is non-existent, returns -1. If the file is a directory and the * authentication scheme is not password, returns -1. * * @return The file's CCSID. * @exception IOException If an error occurs while communicating with the system. **/ public int getCCSID() throws IOException { try { if (impl_ == null) chooseImpl(); if (!isFile()) { if (exists()) { return impl_.getCCSID(); } else { return -1; } } return impl_.getCCSID(true); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /** * Returns the description of the object. Not all objects have descriptions, in which * case a zero-length string is returned. * * @return description of the object. * @throws IOException IOException If an error occurs while communicating with the system. */ public String getDescription() throws IOException { try { if (impl_ == null) chooseImpl(); return impl_.getDescription(); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /** * Returns the full path of the object. * * @return The full path of the object. * **/ public String getFileSystem() { return getPath(); } /** * Returns the amount of unused storage space that is available to the user. * * @return The number of bytes of storage available to the user, or special value {@link Long#MAX_VALUE * Long.MAX_VALUE} if the system reports "no maximum". * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public long getFreeSpace() throws IOException { try { if (impl_ == null) chooseImpl(); return impl_.getAvailableSpace(true); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /** * Returns the amount of unused storage space that is available to the user. * * @param system The system of interest. * @return The number of bytes of storage available to the user, or special value {@link Long#MAX_VALUE * Long.MAX_VALUE} if the system reports "no maximum". * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public static long getFreeSpace(AS400 system) throws IOException { if (system == null) throw new NullPointerException("system"); try { IFSFileImpl impl = (IFSFileImpl) system.loadImpl2("com.ibm.as400.access.IFSFileImplRemote", "com.ibm.as400.access.IFSFileImplProxy"); system.connectService(AS400.FILE); impl.setSystem(system.getImpl()); impl.setPath("/"); return impl.getAvailableSpace(true); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(ExtendedIOException.ACCESS_DENIED); } } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * Returns the amount of unused storage space that is available to the user. Note: If the user profile has a "maximum * storage allowed" setting of *NOMAX, then getAvailableSpace(true) returns the same value as * getAvailableSpace(false). * * @param forUserOnly Whether to report only the space for the user. If false, report space available in the entire * file system. * @return The number of bytes of storage available. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * */ long getAvailableSpace(boolean forUserOnly) throws IOException, AS400SecurityException { if (impl_ == null) chooseImpl(); return impl_.getAvailableSpace(forUserOnly); } /** * Returns the total amount of storage space on the file system. * * @param forUserOnly Whether to report only the space for the user. If false, report total space in the entire file * system. * @return The total number of bytes on the file system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ long getTotalSpace(boolean forUserOnly) throws IOException, AS400SecurityException { if (impl_ == null) chooseImpl(); return impl_.getTotalSpace(forUserOnly); } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE */ IFSFileImpl getImpl() throws IOException, AS400SecurityException { if (impl_ == null) chooseImpl(); return impl_; } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * Package scope getter methods to return data set by listFiles0() * * Number of objects returned by the File Server to listFiles0() and * also the restartName and restartID info of the last object returned. */ int getListFiles0LastNumObjsReturned() { return listFiles0LastNumObjsReturned_; } String getListFiles0LastRestartName() { return (listFiles0LastRestartName_ == null) ? "" : listFiles0LastRestartName_; } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE */ byte[] getListFiles0LastRestartID() { return listFiles0LastRestartID_; } /** * Determines the name of the integrated file system object represented by this object. * * @return The name (without directory components). **/ public String getName() { String name = null; // The name is everything after the last occurrence of the // file separator character. // (Unless quoted, e.g. /parent/"/filename", in which case the name is "/filename", quotes included.) int index = path_.lastIndexOf(separatorChar); if (index >= 0) { if (index < path_.length() - 1) name = path_.substring(index + 1); else name = ""; } else name = path_; // If name contains exactly 1 quote, and there's another quote earlier in the path, back up to the separator // character before the prior quote. int quoteIndex = name.indexOf('"'); if (quoteIndex >= 0) // name includes at least 1 quote { if (quoteIndex == name.lastIndexOf('"')) // we only captured 1 quote { int priorQuoteIndex = path_.lastIndexOf('"', index); if (priorQuoteIndex >= 0) // there's an earlier quote in path { int priorSeparatorIndex = path_.lastIndexOf(separatorChar, priorQuoteIndex); if (priorSeparatorIndex >= 0) // there's a separator prior to 1st quote name = path_.substring(priorSeparatorIndex+1); else // no separator, so back up to beginning of path name = path_; } } } return name; } /** * Returns the name of the user profile that is the owner of the file. * * @return The name of the user profile that owns the file, or "" if owner cannot be determined. If the file is a * directory, only password authentication scheme is supported. * * @exception AS400SecurityException If a security or authority error occurs. * @exception IOException If an error occurs while communicating with the system. * @exception ExtendedIOException If the file does not exist. **/ public String getOwnerName() throws IOException, AS400SecurityException { // Design note: The File Server doesn't support changing the owner name. // It only supports retrieving it. Hence we do not provide a setOwnerName() method. if (impl_ == null) chooseImpl(); // In 7.5 and prior releases, need to create user handle for IFS tables to be initialized. if (!isFile()) return (isDirectory()) ? impl_.getOwnerNameByUserHandle(false) : impl_.getOwnerNameByUserHandle(true); return impl_.getOwnerName(true); } /** * Returns the "user ID number" of the owner of the integrated file system file. * * @return The file owner's ID number, or -1 if the file is non-existent or is a directory. * @exception IOException If an error occurs while communicating with the system. **/ public long getOwnerUID() throws IOException { // Design note: It would be preferable if we could report the user profile name instead of UID number. // However, the File Server doesn't report the user name. FYI: There is a service program (QSYPAPI/getpwuid()) // that reports the user profile name associated with a given uid number, but getpwuid returns its results // as a pointer to a struct, which our ServiceProgramCall class can't handle at the moment. long result = -1L; try { if (impl_ == null) chooseImpl(); result = impl_.getOwnerUID(); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } return result; } /** * Returns the "user ID number" of the owner of the integrated file system file. * * @return The file owner's ID number, or -1 if the file is non-existent or is a directory. * @exception IOException If an error occurs while communicating with the system. * @deprecated Use getOwnerUID() instead. **/ @Deprecated public int getOwnerId() throws IOException { return (int)getOwnerUID(); } /** * Returns the path of the parent directory of the integrated file system object represented by this object. The * parent directory is everything in the path name before the last occurrence of the separator character, or null if * the separator character does not appear in the path name. * * @return The parent directory. * @see #getParentFile() **/ public String getParent() { return getParent(path_); // Note: path_ is never allowed to be null. } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * Returns the parent directory of the file represented by this object. */ static String getParent(String directory) { String parent = null; // The parent directory is everything in the pathname before // the last occurrence of the file separator character. if (!directory.equals(separator)) { if (directory.length() == 0) return null; int index = directory.lastIndexOf(separatorChar); if (index <= 0) // root? parent = separator; else if (index == directory.length() - 1) { // The path has a trailing separator, ignore it. return getParent(directory.substring(0, directory.length() - 1)); } else parent = directory.substring(0, index); } return parent; } /** * Returns the parent directory of the current object. The parent is the path name before the last occurrence of the * separator character. Null is returned if the separator character does not appear in the path, or if the current * object is the file system root. If the system property is not yet set in the current object, then the * system property will not be set in the returned object. * * @return an IFSJavaFile object representing the parent directory if one exists; null otherwise. * * @see #getParent() **/ public IFSFile getParentFile() { String parentPath = getParent(); if (parentPath == null) return null; if (system_ == null) { IFSFile parent = new IFSFile(); try { parent.setPath(parentPath); } catch (PropertyVetoException e) { // will never happen throw new InternalErrorException(InternalErrorException.UNEXPECTED_EXCEPTION, e); } return parent; } return new IFSFile(system_, parentPath); } /** * Returns the path of the integrated file system object represented by this object. * * @return The integrated file system path name. **/ public String getPath() { return path_; } /** * Returns the path of the integrated file system object that is directly pointed to by the symbolic link represented * by this object; or null if the file is not a symbolic link or does not exist. *

* This method is not supported for files in the following file systems: *

    *
  • QSYS.LIB *
  • Independent ASP QSYS.LIB *
  • QDLS *
  • QOPT *
  • QNTC *
* * @return The path directly pointed to by the symbolic link, or null if the IFS object is not a symbolic * link or does not exist. Depending on how the symbolic link was defined, the path may be either relative or * absolute. * * @exception AS400SecurityException If a security or authority error occurs. * @exception IOException If an error occurs while communicating with the system. **/ public String getPathPointedTo() throws IOException, AS400SecurityException { // See if we've already determined that the file isn't a symbolic link. if (cachedAttributes_ != null && !isSymbolicLink_) return null; if (impl_ == null) chooseImpl(); return impl_.getPathPointedTo(); } /** * Returns the pattern-matching behavior used when files are listed by any of the list() or * listFiles() methods. The default is PATTERN_POSIX. * * @return Either {@link #PATTERN_POSIX PATTERN_POSIX}, {@link #PATTERN_POSIX_ALL PATTERN_POSIX_ALL}, or * {@link #PATTERN_OS2 PATTERN_OS2} * @throws IOException If an error occurs while communicating with the system. * @see #setPatternMatching(int) **/ public int getPatternMatching() throws IOException { return patternMatching_; } /** * Returns the permission of the object. * * @return The permission of the object. * @see #setPermission * @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. * @throws UnsupportedEncodingException If the Character Encoding is not supported. * @exception UnknownHostException If the system cannot be located. * **/ public Permission getPermission() throws AS400Exception, AS400SecurityException, ConnectionDroppedException, ErrorCompletingRequestException, InterruptedException, ObjectDoesNotExistException, IOException, UnsupportedEncodingException { if (permission_ == null) permission_ = new Permission(this); return permission_; } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * Returns the Restart ID associated with the file, or null if no attributes have been cached. */ byte[] getRestartID() { if (cachedAttributes_ != null) return cachedAttributes_.getRestartID(); if (Trace.traceOn_) Trace.log(Trace.ERROR, "IFSFile.getRestartID() was called when cachedAttributes_==null."); return null; } /** * Returns the subtype of the integrated file system object represented by this object. Some possible values that * might be returned include:
* CMNF, DKTF, DSPF, ICFF, LF, PF, PRTF, SAVF, TAPF.
* Note that many file system objects do not have a subtype: for example, .MBR objects, and any Root, * QOpenSys or UDFS object. * * @return The subtype of the object, or a zero-length string if the object has no subtype. * @throws IOException If an error occurs while communicating with the system. * * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception AS400SecurityException If a security or authority error occurs. **/ public String getSubtype() throws IOException, AS400SecurityException { if (subType_ == null) { if (impl_ == null) chooseImpl(); subType_ = impl_.getSubtype(); } return subType_; } private boolean isInFileSystem(String fs) { String lowercasePath = path_.toLowerCase().replaceAll("//+","/"); return lowercasePath.equals("/"+fs.toLowerCase()) || lowercasePath.startsWith("/"+fs.toLowerCase()+"/"); } public boolean isInQOpenSys() { return isInFileSystem("QOpenSys"); } public boolean isInQsys() { return isInFileSystem("qsys.lib"); } public boolean isInQDLS() { return isInFileSystem("qdls"); } /** * Determines if the file is an IBM i "source physical file". Physical files reside under QSYS, and can be either * source files (type *SRC) or data files (type *DATA). For further information, refer to the specification of the * QDBRTVFD (Retrieve Database File Description) API. * * @return Whether the file is a source file. * * @exception AS400Exception If the system returns an error message. * @exception AS400SecurityException If a security or authority error occurs. * @exception IOException If an error occurs while communicating with the system. * @see AS400File#TYPE_SOURCE * @see AS400File#TYPE_DATA **/ public boolean isSourcePhysicalFile() throws AS400Exception, AS400SecurityException, IOException { String pathUpperCase = path_.toUpperCase(system_.getLocale()); if (!pathUpperCase.endsWith(".FILE") || pathUpperCase.indexOf("/QSYS.LIB") == -1 || !getSubtype().equals("PF")) { if (Trace.traceOn_) Trace.log(Trace.DIAGNOSTIC, "Not a physical file."); return false; } return impl_.isSourcePhysicalFile(); } /** * Returns the system that this object references. * * @return The system object. **/ public AS400 getSystem() { return system_; } /** * Return the auxiliary storage pool (ASP) that holds the object. * * @param retrieveAll more attributes at same time when set true. * @return Return the auxiliary storage pool (ASP) that holds the object. Possible values are: *
    *
  • 1: the system ASP (QASP01, also known as the system disk pool) *
  • 2 to 32: user ASPs (QASP02 to QASP32) *
  • 33 to 255: independent ASPs *
  • -1: unable to retrieve ASP. *
* @throws IOException If an error occurs while communicating with the system. * @throws AS400SecurityException If a security or authority error occurs. * @deprecated Use {@link #getASP()} **/ @Deprecated public int getASP(boolean retrieveAll) throws IOException, AS400SecurityException { if (impl_ == null) chooseImpl(); return impl_.getASP(); } /** * Return the auxiliary storage pool (ASP) that holds the object. * * @return Return the auxiliary storage pool (ASP) that holds the object. Possible values are: *
    *
  • 1: the system ASP (QASP01, also known as the system disk pool) *
  • 2 to 32: user ASPs (QASP02 to QASP32) *
  • 33 to 255: independent ASPs *
  • -1: unable to retrieve ASP *
* @throws IOException If an error occurs while communicating with the system. * @throws AS400SecurityException If a security or authority error occurs. **/ public int getASP() throws IOException, AS400SecurityException { if (impl_ == null) chooseImpl(); return impl_.getASP(); } /** * Return the type of file system. * * @param retrieveAll true or false, retrieve all attributes at same time. * @return Return the type of file system. Possible values * are: EPFS,QDLS,QSYS,NFS,LRFS,QOPT,QRFS,EPFSP,QNETC,QDTL,IEPFS, and ASPQSYS. * If unable to retrieve file system type, a zero-length string is returned. * @throws IOException If an error occurs while communicating with the system. * @throws AS400SecurityException If a security or authority error occurs. * @deprecated Use {@link #getFileSystemType()} **/ @Deprecated public String getFileSystemType(boolean retrieveAll) throws IOException, AS400SecurityException { if (cachedAttributes_ != null) { int fileSystemType = cachedAttributes_.getFileSystemType(); if (fileSystemType == 2) return "QDLS"; else if (fileSystemType == 3) return "QSYS"; } if (impl_ == null) chooseImpl(); return impl_.getFileSystemType(); } /** * Return the type of file system. * * @return Return the type of file system. Possible values * are: EPFS,QDLS,QSYS,NFS,LRFS,QOPT,QRFS,EPFSP,QNETC,QDTL,IEPFS, and ASPQSYS. * If unable to retrieve file system type, a zero-length string is returned. * @throws IOException If an error occurs while communicating with the system. * @throws AS400SecurityException If a security or authority error occurs. **/ public String getFileSystemType() throws IOException, AS400SecurityException { return getFileSystemType(false); } /** * Computes a hash code for this object. * * @return A hash code value for this object. **/ @Override public int hashCode() { return path_.hashCode(); } /** Provided to initialize transient data if this object is de-serialized. **/ private void initializeTransient() { changes_ = new PropertyChangeSupport(this); vetos_ = new VetoableChangeSupport(this); fileListeners_ = new Vector(); cachedAttributes_ = null; impl_ = null; } /** * Determines if the path name of this integrated file system object is an absolute path name. * * @return true if the path name specification is absolute; false otherwise. **/ public boolean isAbsolute() { // Ensure that the path name is set. if (path_.length() == 0) throw new ExtendedIllegalStateException("path", ExtendedIllegalStateException.PROPERTY_NOT_SET); return (path_.length() > 0 && path_.charAt(0) == '/'); } private boolean isDirectoryInited_ = false; /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * internal isDirectory that returns a return code status indicator */ int isDirectory0() throws IOException, AS400SecurityException { if (cachedAttributes_ != null) { if (isDirectory_) return IFSReturnCodeRep.SUCCESS; else return IFSReturnCodeRep.FILE_NOT_FOUND; } if (isDirectoryInited_) { if (isDirectory_) return IFSReturnCodeRep.SUCCESS; else return IFSReturnCodeRep.FILE_NOT_FOUND; } if (impl_ == null) chooseImpl(); int rc = impl_.isDirectory(); isDirectory_ = (rc == 0) ? true : false; isDirectoryInited_ = true; return rc; } /** * Determines if the integrated file system object represented by this object is a directory.
* Both isDirectory() and {@link #isFile() isFile} will return false for invalid symbolic links. * * @return true if the integrated file system object exists and is a directory; false otherwise. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public boolean isDirectory() throws IOException { int returnCode = IFSReturnCodeRep.FILE_NOT_FOUND; try { returnCode = isDirectory0(); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } return (returnCode == IFSReturnCodeRep.SUCCESS); } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * internal isFile that returns a return code status indicator */ int isFile0() throws IOException, AS400SecurityException { if (cachedAttributes_ != null) { if (isFile_) return IFSReturnCodeRep.SUCCESS; else return IFSReturnCodeRep.FILE_NOT_FOUND; } if (impl_ == null) chooseImpl(); return impl_.isFile(); } /** * Determines if the integrated file system object represented by this object is a "normal" file.
* A file is "normal" if it is not a directory or a container of other objects.
* Both {@link #isDirectory() isDirectory} and isFile() will return false for invalid symbolic links. * * @return true if the specified file exists and is a "normal" file; false otherwise. * @throws IOException If an error occurs while communicating with the system. * * @see #isSymbolicLink() * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. **/ public boolean isFile() throws IOException { int returnCode = IFSReturnCodeRep.FILE_NOT_FOUND; try { returnCode = isFile0(); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } return (returnCode == IFSReturnCodeRep.SUCCESS); } /** * Determines if the integrated file system object represented by this object is hidden. * * @return true if the hidden attribute of this integrated file system object is set; false otherwise. * @throws IOException If an error occurs while communicating with the system. * * @exception AS400SecurityException If a security or authority error occurs. * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. **/ public boolean isHidden() throws IOException, AS400SecurityException { // If the attributes are cached from an earlier listFiles() operation // use the cached attributes instead of getting a new set from the system. if (cachedAttributes_ != null) return (cachedAttributes_.getFixedAttributes() & IFSCachedAttributes.FA_HIDDEN) != 0; if (impl_ == null) chooseImpl(); return impl_.isHidden(); } /** * Determines if the integrated file system object represented by this object is a symbolic link.
* Note: Both {@link #isDirectory() isDirectory} and {@link #isFile() isFile} resolve symbolic links to their ultimate * destination. For example, if this object represents a symbolic link on the system, that resolves to a file object, * then isSymbolicLink() will return true, isFile() will return true, and isDirectory() will return false.
* Note: If the system is V5R2 or earlier, this method always returns false, regardless of whether the system object * is a link or not. * * @return true if the specified file exists and is a symbolic link; false otherwise.
* If the system is V5R2 or earlier, this method always returns false. * @throws IOException If an error occurs while communicating with the system. * @throws AS400SecurityException If a security or authority error occurs. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public boolean isSymbolicLink() throws IOException, AS400SecurityException { if (cachedAttributes_ != null) return isSymbolicLink_; if (impl_ == null) chooseImpl(); return impl_.isSymbolicLink(); } /** * Determines if the integrated file system object represented by this object is read only. * * @return true if the read only attribute of this integrated file system object is set; false otherwise. * @throws IOException If an error occurs while communicating with the system. * * @exception AS400SecurityException If a security or authority error occurs. * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. **/ public boolean isReadOnly() throws IOException, AS400SecurityException { // If the attributes are cached from an earlier listFiles() operation // use the cached attributes instead of getting a new set from the system. if (cachedAttributes_ != null) return (cachedAttributes_.getFixedAttributes() & IFSCachedAttributes.FA_READONLY) != 0; if (impl_ == null) chooseImpl(); return impl_.isReadOnly(); } /** * Returns the sorting behavior used when files are listed by any of the list() or listFiles() * methods. * * @return true if lists of files are returned in sorted order; false otherwise. * @throws IOException If an error occurs while communicating with the system. **/ public boolean isSorted() throws IOException { return sortLists_; } /** * Determines the time that the integrated file system object represented by this object was last accessed. With the * use of the {@link #listFiles() listFiles} methods, attribute information is cached and will not be automatically * refreshed from the system. This means the reported last accessed time may become inconsistent with the system. * * @return The time (measured in milliseconds since 01/01/1970 00:00:00 GMT) that the integrated file system object * was last accessed, or 0L if the object does not exist or is not accessible. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public long lastAccessed() throws IOException { try { if (cachedAttributes_ != null) return cachedAttributes_.getAccessDate(); if (impl_ == null) chooseImpl(); return impl_.lastAccessed(); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * internal length that throws a security exception */ long lastModified0() throws IOException, AS400SecurityException { if (cachedAttributes_ != null) return cachedAttributes_.getModificationDate(); if (impl_ == null) chooseImpl(); return impl_.lastModified(); } /** * Determines the time that the integrated file system object represented by this object was last modified. With the * use of the {@link #listFiles() listFiles} methods, attribute information is cached and will not be automatically * refreshed from the system. This means the reported last modified time may become inconsistent with the system. * * @return The time (measured in milliseconds since 01/01/1970 00:00:00 GMT) that the integrated file system object * was last modified, or 0L if it does not exist or is not accessible. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public long lastModified() throws IOException { try { return lastModified0(); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * internal length that throws a security exception */ long length0() throws IOException, AS400SecurityException { if (cachedAttributes_ != null) return cachedAttributes_.getSize(); if (impl_ == null) chooseImpl(); return impl_.length(); } /** * Determines the length of the integrated file system object represented by this object. With the use of the * {@link #listFiles() listFiles} methods, attribute information is cached and will not be automatically refreshed * from the system. This means the reported length may become inconsistent with the system. * * @return The length, in bytes, of the integrated file system object, or 0L if it does not exist or is not * accessible.
* Note: When used following {@link #listFiles() listFiles} or {@link #enumerateFiles() enumerateFiles} * methods (for symbolic link objects) this method will return the length of the symbolic link object as * returned by the File Server. In order to retrieve the length of the target object, you must use * {@link #clearCachedAttributes() clearCachedAttributes()} followed by {@link #length() length()}. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public long length() throws IOException { try { return length0(); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /** * Lists the integrated file system objects in the directory represented by this object. * * @return An array of object names in the directory. This list does not include the current directory or the parent * directory. If this object does not represent a directory, null is returned. If this object represents an * empty directory, an empty string array is returned.
* Note: Due to a limitation in the File Server, at most 65,535 files will be listed. * @throws IOException If an error occurs while communicating with the system. * * @see #listFiles() * @see #setPatternMatching(int) * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system, or the directory is * not accessible. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public String[] list() throws IOException { return list("*"); } /** * Lists the integrated file system objects in the directory represented by this object that satisfy filter. * * @param filter A file object filter. If null, then no filtering is done. * @return An array of object names in the directory that satisfy the filter. This list does not include the current * directory or the parent directory. If this object does not represent a directory, null is returned. If this * object represents an empty directory, or the filter does not match any files, an empty string array is * returned. The IFSFile object passed to the filter object have cached file attribute information. * Maintaining references to these IFSFile objects after the list operation increases the chances that their * file attribute information will not be valid.
* Note: Due to a limitation in the File Server, at most 65,535 files will be listed. * @throws IOException If an error occurs while communicating with the system. * * @see #listFiles(IFSFileFilter) * @see #setPatternMatching(int) * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system or the directory is * not accessible. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public String[] list(IFSFileFilter filter) throws IOException { return list(filter, "*"); } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * Lists the integrated file system objects in the directory represented by this object that satisfy filter. * * @param filter A file object filter. * * @param pattern The pattern that all filenames must match. Acceptable characters are wildcards (*) and question * marks (?). */ String[] list0(IFSFileFilter filter, String pattern) throws IOException, AS400SecurityException { // Ensure that we are connected to the system. if (impl_ == null) chooseImpl(); // Assume that the 'pattern' argument has been validated as non-null. // Note that we tolerate a null-valued 'filter' argument. // List the attributes of all files in this directory. Have to append // a file separator and * to the path so that all files in the // directory are returned. String directory = path_; if (directory.lastIndexOf(separatorChar) != directory.length() - 1) { // Add a separator character. directory = directory + separatorChar; } String[] allNames = impl_.listDirectoryContents(directory + pattern); // Add the name for each reply that matches the filter to the array // of names. // Changed the behavior of the list() to conform to that of the JDK1.1.x // so that a NULL is returned if and only if the directory or file represented // by this IFSFile object doesn't exist. String[] names = null; if (allNames != null) { names = new String[allNames.length]; int j = 0; for (int i = 0; i < allNames.length; i++) { String name = allNames[i]; boolean addThisOne = false; if (!(name.equals(".") || name.equals(".."))) { addThisOne = false; // Broke up this "double if" check to avoid constructing if (filter == null) // the IFSFile object when there is no filter specified. addThisOne = true; else { IFSFile file = new IFSFile(system_, directory, name); if (filter.accept(file)) addThisOne = true; } // Specified the add in only one place to avoid confusion // over how many add sequences actually take place. if (addThisOne == true) names[j++] = name; } } if (j == 0) names = new String[0]; else if (names.length != j) { // Copy the names to an array of the exact size. String[] newNames = new String[j]; System.arraycopy(names, 0, newNames, 0, j); names = newNames; } } return names; } /** * Lists the integrated file system objects in the directory represented by this object that satisfy filter. * * @param filter A file object filter. * @param pattern The pattern that all filenames must match. Acceptable characters are wildcards (*) and question * marks (?). * @return An array of object names in the directory that satisfy the filter and pattern. This list does not include * the current directory or the parent directory. If this object does not represent a directory, null is * returned. If this object represents an empty directory, or the filter or pattern does not match any files, * an empty string array is returned. The IFSFile object passed to the filter object have cached file * attribute information. Maintaining references to these IFSFile objects after the list operation increases * the chances that their file attribute information will not be valid.
* Note: Due to a limitation in the File Server, at most 65,535 files will be listed. * @throws IOException If an error occurs while communicating with the system. * * @see #listFiles(IFSFileFilter,String) * @see #setPatternMatching(int) * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system or the directory is * not accessible. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public String[] list(IFSFileFilter filter, String pattern) throws IOException { // Validate arguments. Note that we tolerate a null-valued 'filter'. if (pattern == null) throw new NullPointerException("pattern"); try { return list0(filter, pattern); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /** * Lists the integrated file system objects in the directory represented by this object that match pattern. * * @param pattern The pattern that all filenames must match. Acceptable characters are wildcards (*) and question * marks (?). * @return An array of object names in the directory that match the pattern. This list does not include the current * directory or the parent directory. If this object does not represent a directory, null is returned. If this * object represents an empty directory, or the pattern does not match any files, an empty string array is * returned.
* Note: Due to a limitation in the File Server, at most 65,535 files will be listed. * @throws IOException If an error occurs while communicating with the system. * * @see #listFiles(String) * @see #setPatternMatching(int) * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system, or the directory is * not accessible. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public String[] list(String pattern) throws IOException { return list(null, pattern); } /** * Lists the integrated file system objects in the directory represented by this object. With the use of this method, * attribute information is cached and will not be automatically refreshed from the system. This means that retrieving * attribute information for files returned in the list is much faster than using the {@link #list() list} method, but * attribute information may become inconsistent with the system. *

* When the IFSFile object represents the root of the QSYS file system, this method may return a partial list of the * contents of the directory. * * @return An array of objects in the directory. This list does not include the current directory or the parent * directory. If this object does not represent a directory, or this object represents an empty directory, an * empty object array is returned.
* Note: Due to a limitation in the File Server, at most 65,535 files will be listed. * @throws IOException If an error occurs while communicating with the system. * * @see #setPatternMatching(int) * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system, or the directory is * not accessible. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public IFSFile[] listFiles() throws IOException { return listFiles((IFSFileFilter)null, "*"); } /** * Lists the integrated file system objects in the directory represented by this object that satisfy filter. * With the use of this method, attribute information is cached and will not be automatically refreshed from the * system. This means that retrieving attribute information for files returned in the list is much faster than using * the {@link #list(IFSFileFilter) list} method, but attribute information may become inconsistent with the system. *

* When the IFSFile object represents the root of the QSYS file system, this method may return a partial list of the * contents of the directory. * * @param filter A file object filter. * @return An array of objects in the directory. This list does not include the current directory or the parent * directory. If this object does not represent a directory, or this object represents an empty directory, an * empty object array is returned.
* Note: Due to a limitation in the File Server, at most 65,535 files will be listed. * @throws IOException If an error occurs while communicating with the system. * * @see #setPatternMatching(int) * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system, or the directory is * not accessible. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public IFSFile[] listFiles(IFSFileFilter filter) throws IOException { return listFiles(filter, "*"); } /** * Lists the integrated file system objects in the directory represented by this object that satisfy filter. * With the use of this method, attribute information is cached and will not be automatically refreshed from the * system. This means that retrieving attribute information for files returned in the list is much faster than using * the {@link #list(IFSFileFilter,String) list} method, but attribute information may become inconsistent with the * system. *

* When pattern is "*" and the IFSFile object represents the root of the QSYS file system, this method * may return a partial list of the contents of the directory. * * @param filter A file object filter. * @param pattern The pattern that all filenames must match. Acceptable characters are wildcards (*) and question * marks (?). * @return An array of object names in the directory that satisfy the filter and pattern. This list does not include * the current directory or the parent directory. If this object does not represent a directory, this object * represents an empty directory, or the filter or pattern does not match any files, an empty object array is * returned. The IFSFile object passed to the filter object has cached file attribute information. Maintaining * references to these IFSFile objects after the list operation increases the chances that their file * attribute information will not be valid.
* Note: Due to a limitation in the File Server, at most 65,535 files will be listed. * @throws IOException If an error occurs while communicating with the system. * * @see #setPatternMatching(int) * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system, or the directory is * not accessible. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public IFSFile[] listFiles(IFSFileFilter filter, String pattern) throws IOException { // Validate arguments. Note that we tolerate a null-valued 'filter'. if (pattern == null) throw new NullPointerException("pattern"); try { return listFiles0(filter, pattern, -1, (String) null, (byte[]) null, true); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /** * Lists the integrated file system objects in the directory represented by this object that match pattern. * With the use of this method, attribute information is cached and will not be automatically refreshed from the * system. This means that retrieving attribute information for files returned in the list is much faster than using * the {@link #list(String) list} method, but attribute information may become inconsistent with the system. *

* When pattern is "*" and the IFSFile object represents the root of the QSYS file system, this method * may return a partial list of the contents of the directory. * * @param pattern The pattern that all filenames must match. Acceptable characters are wildcards (*) and question * marks (?). * @return An array of object names in the directory that match the pattern. This list does not include the current * directory or the parent directory. If this object does not represent a directory, this object represents an * empty directory, or the pattern does not match any files, an empty object array is returned.
* Note: Due to a limitation in the File Server, at most 65,535 files will be listed. * @throws IOException If an error occurs while communicating with the system. * * @see #setPatternMatching(int) * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system, or the directory is * not accessible. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public IFSFile[] listFiles(String pattern) throws IOException { return listFiles((IFSFileFilter)null, pattern); } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * Lists the integrated file system objects in the directory represented by this object that satisfy filter. * With the use of this method, attribute information is cached and will not be automatically refreshed from the * system. This means attribute information may become inconsistent with the system. * * @param filter A file object filter. * @param pattern The pattern that all filenames must match. * @param maxGetCount The maximum number of directory entries to retrieve. -1 indicates that all entries that match * the search criteria should be retrieved. * @param restartName The file name from which to start the search. If null, the search is started at the beginning of * the list. Acceptable characters are wildcards (*) and question marks (?). */ IFSFile[] listFiles0(IFSFileFilter filter, String pattern, int maxGetCount, String restartName) throws IOException, AS400SecurityException { return listFiles0(filter, pattern, maxGetCount, restartName, null, true); //@D7C } /** Lists the integrated file system objects in the directory represented by this object that satisfy filter. With the use of this method, attribute information is cached and will not be automatically refreshed from the system. This means attribute information may become inconsistent with the system. @param filter A file object filter. @param pattern The pattern that all filenames must match. Acceptable characters are wildcards (*) and question marks (?). **/ private IFSFile[] listFiles0(IFSFileFilter filter, String pattern, int maxGetCount, String restartName, byte[] restartID, boolean allowSortedRequests) throws IOException, AS400SecurityException { // Do not specify both restartName and restartID. Specify one or the other. // Ensure that we are connected to the system. if (impl_ == null) chooseImpl(); // Assume that the 'pattern' argument has been validated as non-null. // Note that we tolerate a null-valued 'filter' argument. // List the attributes of all files in this directory. Have to append // a file separator and * to the path so that all files in the // directory are returned. String directory = path_; if (directory.lastIndexOf(separatorChar) != directory.length() - 1) directory = directory + separatorChar; IFSCachedAttributes[] fileAttributeList; if (restartName != null) fileAttributeList = impl_.listDirectoryDetails(directory + pattern, directory, maxGetCount, restartName); else fileAttributeList = impl_.listDirectoryDetails(directory + pattern, directory, maxGetCount, restartID,allowSortedRequests); // Add the name for each reply that matches the filter to the array of files. if (Trace.isTraceOn()) Trace.log(Trace.DIAGNOSTIC, "IFSFile::listFile0(): returned ("+listFiles0LastNumObjsReturned_+") pre objects"); if (fileAttributeList == null) return new IFSFile[0]; // Save number of objects read, restartname, and restartID listFiles0LastNumObjsReturned_ = fileAttributeList.length; IFSFile[] files = new IFSFile[fileAttributeList.length]; if (fileAttributeList.length > 0) { IFSFile lastFile = new IFSFile(system_, fileAttributeList[fileAttributeList.length - 1]); // Save the last restartName and restartID from the files // returned from the server (to be used for subsequent reads) listFiles0LastRestartName_ = lastFile.getName(); listFiles0LastRestartID_ = lastFile.getRestartID(); } int j = 0; for (int i = 0; i < fileAttributeList.length; i++) { IFSFile file = new IFSFile(system_, fileAttributeList[i]); if (filter == null || filter.accept(file)) files[j++] = file; } if (j == 0) files = new IFSFile[0]; else if (files.length != j) { // Copy the objects to an array of the exact size. IFSFile[] newFiles = new IFSFile[j]; System.arraycopy(files, 0, newFiles, 0, j); files = newFiles; } if (Trace.isTraceOn()) Trace.log(Trace.DIAGNOSTIC, "IFSFile::listFile0(): returned ("+files.length+") post objects"); return files; } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE */ IFSFile[] listFiles0(IFSFileFilter filter, String pattern, int maxGetCount, byte[] restartID) throws IOException, AS400SecurityException { // This method is only called by IFSEnumeration() which reads 128 objects at a time. @D7A // The IFS file server does not allow "sort" and "restart ID" to be set in the same server request. // Therefore, since the user may have previously called setSorted(), we need to inform // IFSFileImplRemote to not allow sorting on this server request. The last parameter // indicates "allowSortedRequests" and is set to "false" return listFiles0(filter, pattern, maxGetCount, null, restartID, false); } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE */ IFSFile[] listFiles0(IFSFileFilter filter, String pattern) throws IOException, AS400SecurityException { return listFiles0(filter, pattern, -1, null, null, true); } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * internal mkdirs that returns return codes and throws exceptions */ int mkdir0(String directory) throws IOException, AS400SecurityException { // Assume the argument has been validated as non-null. if (impl_ == null) chooseImpl(); return impl_.mkdir(directory); } /** * Creates an integrated file system directory whose path name is specified by this object. * * @return true if the directory was created; false otherwise. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public boolean mkdir() throws IOException { int returnCode = IFSReturnCodeRep.FILE_NOT_FOUND; try { returnCode = mkdir0(path_); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } return (returnCode == IFSReturnCodeRep.SUCCESS); } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * internal mkdirs that returns return codes and throws exceptions */ int mkdirs0() throws IOException, AS400SecurityException { if (impl_ == null) chooseImpl(); return impl_.mkdirs(); } /** * Creates an integrated file system directory whose path name is specified by this object. In addition, create all * parent directories as necessary. * * @return true if the directory (or directories) were created; false otherwise. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public boolean mkdirs() throws IOException { int returnCode = IFSReturnCodeRep.FILE_NOT_FOUND; try { returnCode = mkdirs0(); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } return (returnCode == IFSReturnCodeRep.SUCCESS); } /* * Restores the state of this object from an object input stream. * * @param ois The stream of state information. * @exception IOException * @exception ClassNotFoundException */ private void readObject(java.io.ObjectInputStream ois) throws IOException, ClassNotFoundException { // Restore the non-static and non-transient fields. ois.defaultReadObject(); // Initialize the transient fields. initializeTransient(); } /** * Removes a file listener so that it no longer receives file events from this IFSFile. * * @param listener The file listener. **/ public void removeFileListener(FileListener listener) { if (listener == null) throw new NullPointerException("listener"); fileListeners_.removeElement(listener); } /** * Removes a property change listener. * * @param listener The property change listener to remove. **/ public void removePropertyChangeListener(PropertyChangeListener listener) { if (listener == null) throw new NullPointerException("listener"); changes_.removePropertyChangeListener(listener); } /** * Removes a vetoable change listener. * * @param listener The vetoable change listener to remove. **/ public void removeVetoableChangeListener(VetoableChangeListener listener) { if (listener == null) throw new NullPointerException("listener"); vetos_.removeVetoableChangeListener(listener); } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * internal renameTo that returns an error code */ int renameTo0(IFSFile file) throws IOException, PropertyVetoException, AS400SecurityException { // Assume the argument has been validated as non-null. if (impl_ == null) chooseImpl(); String targetPath = file.getAbsolutePath(); if (targetPath.length() == 0) throw new ExtendedIllegalStateException("path", ExtendedIllegalStateException.PROPERTY_NOT_SET); // Fire a vetoable change event. vetos_.fireVetoableChange("path", path_, file.getAbsolutePath()); // Rename the file. int rc = impl_.renameTo(file.getImpl()); if (rc == IFSReturnCodeRep.SUCCESS) { String oldPath = path_; path_ = file.getAbsolutePath(); // Fire the property change event having null as the name to // indicate that the path, parent, etc. have changed. changes_.firePropertyChange("path", oldPath, path_); // Clear any cached attributes. cachedAttributes_ = null; } return rc; } /** * Renames the integrated file system object specified by this object to have the path name of file. Wildcards * are not permitted in this file name. * * @param file The new file name. * * @return true if successful; false otherwise. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception PropertyVetoException If the change is vetoed. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * **/ public boolean renameTo(IFSFile file) throws IOException, PropertyVetoException { // Validate the argument. if (file == null) throw new NullPointerException("file"); int returnCode = IFSReturnCodeRep.FILE_NOT_FOUND; try { returnCode = renameTo0(file); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } return (returnCode == IFSReturnCodeRep.SUCCESS); } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * Sets the access mode of the integrated file system object. This method is supported for IBM i V5R1 and higher. For * older releases, it does nothing and returns false. * * @param accessType The type of access to set on the file. Valid values are:

  • {@link #ACCESS_READ * ACCESS_READ}
  • {@link #ACCESS_WRITE ACCESS_WRITE}
  • {@link #ACCESS_EXECUTE ACCESS_EXECUTE}
* * @param accessMode If true, sets the access permission to allow the specified type of operation; if false, to * disallow the operation. * * @param ownerOnly If true, the specified permission applies only to the owner's permission; otherwise, it applies to * everybody. * * @return true if successful; false otherwise. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. */ boolean setAccess(int accessType, boolean enableAccess, boolean ownerOnly) throws IOException, AS400SecurityException { // Note: The called API (QlgChmod) is supported for V5R1 and higher. // The impl object will check the VRM. if (accessType != ACCESS_READ && accessType != ACCESS_WRITE && accessType != ACCESS_EXECUTE) throw new ExtendedIllegalArgumentException("accessType ("+accessType+")", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID); if (impl_ == null) chooseImpl(); return impl_.setAccess(accessType, enableAccess, ownerOnly); } /** * Sets the file's data CCSID. * * @param ccsid The file data CCSID. Note that the data in the file is not changed; only the CCSID "tag" on the file * is changed. * @return true if successful; false otherwise. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system, or if the file * doesn't exist or is a directory. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. **/ public boolean setCCSID(int ccsid) throws IOException { boolean success = false; try { if (impl_ == null) chooseImpl(); success = impl_.setCCSID(ccsid); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } if (success) { // Fire the file modified event. if (fileListeners_.size() != 0) IFSFileDescriptor.fireModifiedEvents(this, fileListeners_); } return success; } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * Changes the fixed attributes (read only, hidden, etc.) of the integrated file system object represented by this * object to attributes. * * @param attributes The attributes to set on the file. These attributes are not ORed with existing attributes. * They replace the existing fixed attributes of the file. The attributes are a bit map as follows
  • 0x0001: on * = file is a readonly file
  • 0x0002: on = file is a hidden file
  • 0x0004: on = file is a system file
  • 0x0010: * on = file is a directory
  • 0x0020: on = file has been changed (archive bit)
For example, 0x0023 is a * readonly, hidden file with the archive bit on. * * @return true if successful; false otherwise. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. */ boolean setFixedAttributes(int attributes) throws IOException { // Validate arguments. if ((attributes & 0xFFFFFF00) != 0) throw new ExtendedIllegalArgumentException("attributes ("+attributes+")", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID); try { if (impl_ == null) chooseImpl(); boolean success = impl_.setFixedAttributes(attributes); if (success) cachedAttributes_ = null; return success; } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /** * Marks the integrated file system object represented by this object as hidden. * * @return true if successful; false otherwise. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. **/ public boolean setHidden() throws IOException { return setHidden(true); } /** * Changes the hidden attribute of the integrated file system object represented by this object. * * @param attribute True to set the hidden attribute of the file. False to turn off the hidden attribute. * * @return true if successful; false otherwise. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. **/ public boolean setHidden(boolean attribute) throws IOException { try { if (impl_ == null) chooseImpl(); boolean success = impl_.setHidden(attribute); if (success) { cachedAttributes_ = null; // Fire the file modified event. if (fileListeners_.size() != 0) IFSFileDescriptor.fireModifiedEvents(this, fileListeners_); } return success; } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /** * Changes the last modified time of the integrated file system object represented by this object to time. * * @param time The desired last modification time (measured in milliseconds since January 1, 1970 00:00:00 GMT), or 0 * to leave the last modification time unchanged, or -1 to set the last modification time to the current * system time. * * @return true if successful; false otherwise. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * @exception PropertyVetoException If the change is vetoed. **/ public boolean setLastModified(long time) throws IOException, PropertyVetoException { // Fire a vetoable change event for lastModified. vetos_.fireVetoableChange("lastModified", null, Long.valueOf(time)); try { return setLastModified0(time); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /** * Beans friendly version of setLastModified. * * @param time * @throws IOException If an error occurs while communicating with the system. * @throws PropertyVetoException If the recipient wishes the property change to be rolled back. */ public void setLastModifiedV(long time) throws IOException, PropertyVetoException { setLastModified(time); } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * Changes the last modified time of the integrated file system object represented by this object to time. * * @param time The desired last modification time (measured in milliseconds since January 1, 1970 00:00:00 GMT), or 0 * to leave the last modification time unchanged, or -1 to set the last modification time to the current system time. * * @return true if successful; false otherwise. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. * @exception PropertyVetoException If the change is vetoed. */ boolean setLastModified0(long time) throws IOException, AS400SecurityException { // Validate arguments. if (time < -1) { throw new ExtendedIllegalArgumentException("time (" + Long.toString(time) + ")", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID); } if (impl_ == null) chooseImpl(); boolean success = impl_.setLastModified(time); if (success) { // Fire the property change event. changes_.firePropertyChange("lastModified", null, Long.valueOf(time)); // Fire the file modified event. if (fileListeners_.size() != 0) IFSFileDescriptor.fireModifiedEvents(this, fileListeners_); // Clear any cached attributes. cachedAttributes_ = null; } return success; } /** * Sets the length of the integrated file system object represented by this object. The file can be made larger or * smaller. If the file is made larger, the contents of the new bytes of the file are undetermined. * * @param length The new length, in bytes. * @return true if successful; false otherwise. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. **/ public boolean setLength(int length) throws IOException { try { return setLength0(length); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * Sets the length of the integrated file system object represented by this object. The file can be made larger or * smaller. If the file is made larger, the contents of the new bytes of the file are undetermined. * * @param length The new length, in bytes. * * @return true if successful; false otherwise. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. */ boolean setLength0(int length) throws IOException, AS400SecurityException { // Validate arguments. if (length < 0) { throw new ExtendedIllegalArgumentException("length (" + Integer.toString(length) + ")", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID); } // Note: The file system will not allow us to set the length of a file to a value larger than (2Gig minus 1), // or 2147483647 (0x7FFFFFFF) bytes, which happens to be the maximum positive value which an 'int' will hold. // Therefore we do not provide a setLength(long) method. if (impl_ == null) chooseImpl(); boolean success = impl_.setLength(length); if (success) { // Fire the file modified event. if (fileListeners_.size() != 0) IFSFileDescriptor.fireModifiedEvents(this, fileListeners_); // Clear any cached attributes. cachedAttributes_ = null; } return success; } /** * Sets the file path. An exception will be returned if the IFSFile object * has been operated on that results in a server connection being established. * * @param path The absolute file path. * @exception PropertyVetoException If the change is vetoed. **/ public void setPath(String path) throws PropertyVetoException { if (path == null) throw new NullPointerException("path"); // Ensure that the path is not altered after the connection is established. if (impl_ != null) throw new ExtendedIllegalStateException("path", ExtendedIllegalStateException.PROPERTY_NOT_CHANGED); // Remember the current path value. String oldPath = path_; // If the specified path doesn't start with the separator character, // add one. All paths are absolute for IFS. String newPath = normalizePath(null, path); // Fire a vetoable change event for the path. vetos_.fireVetoableChange("path", oldPath, newPath); // Update the path value. path_ = newPath; // Fire the property change event having null as the name to // indicate that the path, parent, etc. have changed. changes_.firePropertyChange("path", oldPath, newPath); } /** * Sets the pattern-matching behavior used when files are listed by any of the list() or listFiles() * methods. The default is PATTERN_POSIX. * * @param patternMatching Either {@link #PATTERN_POSIX PATTERN_POSIX}, {@link #PATTERN_POSIX_ALL PATTERN_POSIX_ALL}, * or {@link #PATTERN_OS2 PATTERN_OS2} * @throws IOException If an error occurs while communicating with the system. * * @see #getPatternMatching() * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. **/ public void setPatternMatching(int patternMatching) throws IOException { if (patternMatching < PATTERN_POSIX || patternMatching > PATTERN_OS2) { throw new ExtendedIllegalArgumentException("patternMatching ("+patternMatching+")", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID); } if (impl_ == null) { try { chooseImpl(); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } impl_.setPatternMatching(patternMatching); patternMatching_ = patternMatching; } /** * Sets the permission of the object. * * @param permission The permission that will be set to the object. * @see #getPermission * @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. * @throws ServerStartupException If the server cannot be started. * @exception PropertyVetoException If the change is vetoed. * @exception UnknownHostException If the system cannot be located. * **/ public void setPermission(Permission permission) throws AS400Exception, AS400SecurityException, ConnectionDroppedException, ErrorCompletingRequestException, InterruptedException, IOException, ObjectDoesNotExistException, ServerStartupException, PropertyVetoException, UnknownHostException { if (permission == null) throw new NullPointerException("permission"); AS400 system=permission.getSystem(); if (system == null) throw new ExtendedIllegalArgumentException("permission.system (null)", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID); if (system.equals(system_)) { if ((this.getFileSystem()).equals(permission.getObjectPath())) { vetos_.fireVetoableChange("permission", null, permission_); this.permission_=permission; permission.commit(); changes_.firePropertyChange("permission", null, permission_); } else { throw new ExtendedIllegalArgumentException("permission.objectPath (" + permission.getObjectPath() + ")", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID); } } else { String systemName = system.getSystemName(); throw new ExtendedIllegalArgumentException("permission.system (" + systemName + ")", ExtendedIllegalArgumentException.PARAMETER_VALUE_NOT_VALID); } } /** * Marks the integrated file system object represented by this object so that only read operations are allowed. * * @return true if successful; false otherwise. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. **/ public boolean setReadOnly() throws IOException { return setReadOnly(true); } /** * Changes the read only attribute of the integrated file system object represented by this object. * * @param attribute True to set the read only attribute of the file such that the file cannot be changed. False to set * the read only attributes such that the file can be changed. * * @return true if successful; false otherwise. * @throws IOException If an error occurs while communicating with the system. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. **/ public boolean setReadOnly(boolean attribute) throws IOException { try { return setReadOnly0(attribute); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } /** * INTERNAL USE ONLY - SUBJECT TO CHANGE * * Changes the read only attribute of the integrated file system object represented by this object. * * @param attribute True to set the read only attribute of the file such that the file cannot be changed. False to set * the read only attributes such that the file can be changed. * * @return true if successful; false otherwise. * * @exception ConnectionDroppedException If the connection is dropped unexpectedly. * @exception ExtendedIOException If an error occurs while communicating with the system. * @exception InterruptedIOException If this thread is interrupted. * @exception ServerStartupException If the host server cannot be started. * @exception UnknownHostException If the system cannot be located. **/ boolean setReadOnly0(boolean attribute) throws IOException, AS400SecurityException { if (impl_ == null) chooseImpl(); boolean success = impl_.setReadOnly(attribute); if (success) { cachedAttributes_ = null; // Fire the file modified event. if (fileListeners_.size() != 0) IFSFileDescriptor.fireModifiedEvents(this, fileListeners_); } return success; } /** * Sets the sorting behavior used when files are listed by any of the list() or listFiles() methods. * The default is false (unsorted). * * @param sort If true: Lists of files are returned in sorted order. If false: Lists of files are * returned in whatever order the file system provides. * * @exception IOException If an error occurs while communicating with the system. * @exception AS400SecurityException If a security or authority error occurs. **/ public void setSorted(boolean sort) throws IOException, AS400SecurityException { if (impl_ == null) { try { chooseImpl(); } catch (AS400SecurityException e) { Trace.log(Trace.ERROR, SECURITY_EXCEPTION, e); throw new ExtendedIOException(path_, ExtendedIOException.ACCESS_DENIED); } } impl_.setSorted(sort); sortLists_ = sort; } /** * Sets the system. The system cannot be changed once a connection is made to the system. * * @param system The system object. * @exception PropertyVetoException If the change is vetoed. **/ public void setSystem(AS400 system) throws PropertyVetoException { if (system == null) throw new NullPointerException("system"); // Ensure that system is not altered after the connection is // established. if (impl_ != null) { Trace.log(Trace.ERROR, "Cannot set property 'system' after connect."); throw new ExtendedIllegalStateException("system", ExtendedIllegalStateException.PROPERTY_NOT_CHANGED); } // Fire a vetoable change event for system. vetos_.fireVetoableChange("system", system_, system); // Remember the old system value. AS400 oldSystem = system_; system_ = system; // Fire the property change event. changes_.firePropertyChange("system", oldSystem, system_); } /** * Generates a String representation of this object. * * @return The path name of the integrated file system object represented by this object. **/ @Override public String toString() { return path_; } /* * INTERNAL USE ONLY - SUBJECT TO CHANGE * * This function normalizes the path of the object in IFSFile. If a directory path * is passed, it will be prepended to the path (or name). It will also ensure * that the resultant path is absolute (i.e. starts from the root ('/')). * * Note: The path parameter can be a simple name or path. */ static String normalizePath(String dir, String path) { StringBuilder sb = new StringBuilder(); // Include directory in path if there is one. if (dir != null) { sb.append(dir); if (path != null && sb.length() != 0 && sb.charAt(sb.length() - 1) != separatorChar) sb.append(separatorChar); } // If path/name specified, append it. if (path != null) sb.append(path); // If the specified path doesn't start with the separator character, // add one. All paths are absolute for IFS. if (sb.length() == 0 || sb.charAt(0) != separatorChar) sb.insert(0, separatorChar); return sb.toString(); } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy