Integration Toolbox
for IBM® TIVOLI® Storage Manager

package archive_retrieve; import hu.user.toolbox.tsm.IArchiveObject; import hu.user.toolbox.tsm.IArchiveObjectList; import hu.user.toolbox.tsm.IFilespace; import hu.user.toolbox.tsm.IResultSet; import hu.user.toolbox.tsm.ITSMSession; import hu.user.toolbox.tsm.Toolbox; import hu.user.toolbox.tsm.exception.ToolboxException; import hu.user.toolbox.tsm.query.IArchiveQuery; import java.io.FileOutputStream; import java.io.IOException; /** * <b>Function:</b><br> * Retrieves the archived object that was previously sent to the server using * the ArchiveSingleObject example. * <p> * Before executing this program send an object to the server using * the ArchiveSingleObject sample. * <p> * The following operations are performed: * <ol> * <li>Initializing a single-threaded TSM API environment.</li> * <li>Creating a new TSMSession instance. * Setting default connection options. Connecting to the server using * the node name "TOOLBOX" and password "PASSWORD".</li> * <li>Retrieving the filespace named "/ARCHIVEFS"</li> * <li>Querying archive objects with the parameters: * high-level name "/ARCHIVE", low-level name "/* and object type "FILE"</li> * <li>Iterating through the returned ResultSet, adding each object * to the retrieve list, then closing the result set.</li> * <li>Retrieving the first object "/OBJECT1" to the folder "results" * with the name "retrieve.txt"</li> * <li>Disconnecting from the server and cleaning up the resources.</li> * </ol> * <p> * <b>Compile:</b> * <pre> * javac -d bin -cp ../lib/toolboxfortsm.jar archive_retrieve/RetrieveSingleObject.java * </pre> * <p> * <b>Execute:</b><br> * You should first set the environment variables to point to the correct * files/directories. * <pre> * set DSMI_CONFIG={Full path of your dsm.opt} * set DSMI_DIR={Tivoli Storage Manager API installation directory} * set DSMI_LOG={Any arbitrary directory} * </pre> * Then use the java command to execute the program: * <p> * <pre> * java -cp bin:../lib/toolboxfortsm.jar:../lib/ext/log4j-1.2.17.jar:../config * -Djava.library.path=../lib archive_retrieve.RetrieveSingleObject * </pre> */ public class RetrieveSingleObject { private static final String NODE_NAME = "TOOLBOX"; private static final String PASSWORD = "PASSWORD"; private static final String LOW_LEVEL_NAME = "/OBJECT1"; private static final String OUTPUT_FILE_NAME = "results/retrieved.txt"; private static final String HIGH_LEVEL_NAME = "/ARCHIVE"; private static final String FILESPACE_NAME = "/ARCHIVEFS"; public static void main(final String args[]) throws IOException, ToolboxException { ITSMSession session = null; try { // Initializing a single-threaded environment Toolbox.initSingleThreading(); // Connecting to the server with the default connection options session = Toolbox.createSession(NODE_NAME, PASSWORD); // Retrieving the existing filespace from server IFilespace filespace = session.retrieveFilespace(FILESPACE_NAME); IArchiveObjectList archiveList = session.createArchiveObjectList(); // Checking if filespace exists if (filespace == null) { System.out.printf("Warning: '%s' does not exists.\n", FILESPACE_NAME); return; } IArchiveObject archiveObject = null; IArchiveQuery archiveQuery = filespace.createArchiveQuery(); IResultSet archiveObjects = null; try{ // Querying all archive objects of the filespace matching the specified criteria archiveObjects = archiveQuery .highLevelNameMatches(HIGH_LEVEL_NAME) .lowLevelNameMatches(LOW_LEVEL_NAME) .ownerMatchesAny() // Matches any owner name .files() // Query for files .execute(); // Execute the query // Iterating over the returned result set while (archiveObjects.next()) { archiveObject = (IArchiveObject) archiveObjects.get(); break; } }catch (Exception e) { e.printStackTrace(); }finally{ // The result set must be closed. archiveObjects.close(); } // Check if object has been archived. if (archiveObject == null) { System.out.printf("The object '%s%s%s' doesn't exist on the server.\n", FILESPACE_NAME, HIGH_LEVEL_NAME, LOW_LEVEL_NAME); return; } // Starting the retrieve operation archiveList.add(archiveObject); archiveList.beginRetrieve(); FileOutputStream out = new FileOutputStream(OUTPUT_FILE_NAME); // Doing the actual retrieve. try { archiveObject.retrieve(out); System.out.printf("The object '%s%s%s' has been retrieved to file '%s'.\n", FILESPACE_NAME, HIGH_LEVEL_NAME, LOW_LEVEL_NAME, OUTPUT_FILE_NAME); } catch (Exception e) { e.printStackTrace(); } finally{ // Finishing the retrieve operation. archiveList.endRetrieve(); } } catch (ToolboxException e) { e.printStackTrace(); } finally { // Disconnecting session.disconnect(); // Cleaning up the environment Toolbox.cleanUp(); } } }