IOExitResourcePath.java interface
IOExitResourcePath.java
/* * Licensed Materials - Property of IBM * * "Restricted Materials of IBM" * * 5724-H72 * * Copyright IBM Corp. 2011, 2020. All Rights Reserved. * * disclosure restricted by GSA ADP Schedule Contract with * IBM Corp. */ package com.ibm.wmqfte.exitroutine.api; import java.io.IOException; /** * Represents a path that denotes a data resource (for example, a file, * directory, or group of database records). It allows the data to be located * and {@link IOExitChannel} instances to be created for read or write * operations. * <p> * There are two types of data resources as follows: * <ul> * <li>Directory - a container for other data resources. The * {@link #isDirectory()} method returns {@code true} for these.</li> * <li>File - a data container. This allows data to be read from or written to * it. The {@link #isFile()} method returns {@code true} for these.</li> * </ul> */ public interface IOExitResourcePath extends IOExitPath { /** * Creates a new {@link IOExitResourcePath} instance for a child path of the * resource denoted by this abstract path. * <p> * For example, with a UNIX-style path, {@code * IOExitResourcePath("/home/fteuser/test").newPath("subtest")} could be * equivalent to: {@code IOExitResourcePath("/home/fteuser/test/subtest")} * * @param child * The child path name. * @return A new {@link IOExitResourcePath} instance that represents a child * of this path. */ IOExitResourcePath newPath(final String child); /** * Creates the directory path for the resource denoted by this abstract * path, including any necessary but nonexistent parent directories. If the * directory path already exists, this method has no effect. * <p> * If this operation fails, it might have succeeded in creating some of the * necessary parent directories. * * @throws IOException * If the directory path cannot be fully created, when it does * not already exist. */ void makePath() throws IOException; /** * Obtains the canonical path of the abstract path as a {@link String}. * <p> * A canonical path is defined as being absolute and unique. For example, * the path can be represented as UNIX-style relative path: {@code * test/file.txt} but the absolute and unique canonical path representation * is: {@code /home/fteuser/test/file.txt} * * @return The canonical path as a {@link String}. * @throws IOException * If the canonical path cannot be determined for any reason. */ String getCanonicalPath() throws IOException; /** * Tests if this abstract path is an absolute path. * <p> * For example, a UNIX-style path, {@code /home/fteuser/test} is an absolute * path, whereas {@code fteuser/test} is not. * * @return {@code true} if this abstract path is an absolute path, {@code * false} otherwise. */ boolean isAbsolute(); /** * Tests if the resource denoted by this abstract path exists. * * @return {@code true} if the resource denoted by this abstract path * exists, {@code false} otherwise. * @throws IOException * If the existence of the resource cannot be determined for any * reason. */ boolean exists() throws IOException; /** * Tests whether the calling application can read the resource denoted by * this abstract path. * * @return {@code true} if the resource for this path exists and can be * read, {@code false} otherwise. * @throws IOException * If a problem occurs while attempting to determine if the * resource can be read. */ boolean canRead() throws IOException; /** * Tests whether the calling application can modify the resource denoted by * this abstract path. * * @return {@code true} if the resource for this path exists and can be * modified, {@code false} otherwise. * @throws IOException * If a problem occurs while attempting to determine if the * resource can be modified. */ boolean canWrite() throws IOException; /** * Tests whether the specified user is permitted to read the resource * denoted by this abstract path. * <p> * When WMQFTE invokes this method, the user identifier is the MQMD user * identifier for the requesting transfer. * * @param userId * User identifier to test for access. * @return {@code true} if the resource for this abstract path exists and is * permitted to be read by the specified user, {@code false} * otherwise. * @throws IOException * If a problem occurs while attempting to determine if the user * is permitted to read the resource. */ boolean readPermitted(String userId) throws IOException; /** * Tests whether the specified user is permitted to modify the resource * denoted by this abstract path. * <p> * When WMQFTE invokes this method, the user identifier is the MQMD user * identifier for the requesting transfer. * * @param userId * User identifier to test for access. * @return {@code true} if the resource for this abstract path exists and is * permitted to be modified by the specified user, {@code false} * otherwise. * @throws IOException * If a problem occurs while attempting to determine if the user * is permitted to modify the resource. */ boolean writePermitted(String userId) throws IOException; /** * Tests if the resource denoted by this abstract path is a directory-type * resource. * * @return {@code true} if the resource denoted by this abstract path is a * directory type resource, {@code false} otherwise. */ boolean isDirectory(); /** * Creates the resource denoted by this abstract path, if it does not * already exist. * * @return {@code true} if the resource does not exist and was successfully * created, {@code false} if the resource already existed. * @throws RecoverableIOException * If a recoverable problem occurs while attempting to create * the resource. This means that WMQFTE can attempt to recover * the transfer. * @throws IOException * If some other I/O problem occurs. */ boolean createNewPath() throws RecoverableIOException, IOException; /** * Tests if the resource denoted by this abstract path is a file-type * resource. * * @return {@code true} if the resource denoted by this abstract path is a * file type resource, {@code false} otherwise. */ boolean isFile(); /** * Obtains the last modified time for the resource denoted by this abstract * path. * <p> * This time is measured in milliseconds since the epoch (00:00:00 GMT, * January 1, 1970). * * @return The last modified time for the resource denoted by this abstract * path, or a value of 0L if the resource does not exist or a * problem occurs. */ long lastModified(); /** * Deletes the resource denoted by this abstract path. * <p> * If the resource is a directory, it must be empty for the delete to work. * * @throws IOException * If the delete of the resource fails for any reason. */ void delete() throws IOException; /** * Renames the resource denoted by this abstract path to the specified * destination abstract path. * <p> * The rename should still be successful if the resource for the specified * destination abstract path already exists and it is possible to replace * it. * * @param destination * The new abstract path for the resource denoted by this * abstract path. * @throws IOException * If the rename of the resource fails for any reason. */ void renameTo(IOExitResourcePath destination) throws IOException; /** * Creates a new path to use for writing to a temporary resource that did * not previously exist. * <p> * The implementation can choose the abstract path name for the temporary * resource. However, for clarity and problem diagnosis, the abstract path * name for the temporary resource should be based on this abstract path * name with the specified suffix appended and additional characters to make * the path unique (for example, sequence numbers), as required. * <p> * When WMQFTE transfers data to a destination it normally attempts to first * write to a temporary resource then on transfer completion renames the * temporary resource to the required destination. This method is called by * WMQFTE to create a new temporary resource path. The returned path should * be new and the resource should not previously exist. * * @param suffix * Recommended suffix to use for the generated temporary path. * * @return A new {@link IOExitResourcePath} instance for the temporary * resource path, that did not previously exist. * @throws RecoverableIOException * If a recoverable problem occurs whilst attempting to create * the temporary resource. This means that WMQFTE can attempt to * recover the transfer. * @throws IOException * If some other I/O problem occurs. */ IOExitResourcePath createTempPath(String suffix) throws RecoverableIOException, IOException; /** * Opens a {@link IOExitChannel} instance for reading data from the resource * denoted by this abstract path. The current data byte position for the * resource is expected to be the passed position value, such that when * {@link IOExitChannel#read(java.nio.ByteBuffer)} is called, data starting * from that position is read. * * @param position * The required data byte read position. * @return A new {@link IOExitChannel} instance allowing data to be read * from the resource denoted by this abstract path. * @throws RecoverableIOException * If a recoverable problem occurs while attempting to open the * resource for reading. This means that WMQFTE can attempt to * recover the transfer. * @throws IOException * If some other I/O problem occurs. */ IOExitChannel openForRead(long position) throws RecoverableIOException, IOException; /** * Opens a {@link IOExitChannel} instance for writing data to the resource * denoted by this abstract path. Writing of data, using the * {@link IOExitChannel#write(java.nio.ByteBuffer)} method, starts at either * the beginning of the resource or end of the current data for the * resource, depending on the specified append parameter. * * @param append * When {@code true} indicates that data written to the resource * should be appended to the end of the current data. When * {@code false} indicates that writing of data is to start at * the beginning of the resource; any existing data is lost. * @return A new {@link IOExitChannel} instance allowing data to be written * to the resource denoted by this abstract path. * @throws RecoverableIOException * If a recoverable problem occurs whilst attempting to open the * resource for writing. This means that WMQFTE can attempt to * recover the transfer. * @throws IOException * If some other I/O problem occurs. */ IOExitChannel openForWrite(boolean append) throws RecoverableIOException, IOException; /** * Tests if the resource denoted by this abstract path is in use by another * application. Typically, this is because another application has a lock on * the resource either for shared or exclusive access. * * @return {code true} if resource denoted by this abstract path is in use * by another application, {@code false} otherwise. */ boolean inUse(); /** * Obtains a {@link IOExitProperties} instance for properties associated * with the resource denoted by this abstract path. * <p> * WMQFTE will read these properties to govern how a transfer behaves when * interacting with the resource. * * @return A {@link IOExitProperties} instance for properties associated * with the resource denoted by this abstract path. */ IOExitProperties getProperties(); }