/* * CDDL HEADER START * * The contents of this file are subject to the terms of the * Common Development and Distribution License, Version 1.0 only * (the "License"). You may not use this file except in compliance * with the License. * * You can obtain a copy of the license at * trunk/opends/resource/legal-notices/OpenDS.LICENSE * or https://OpenDS.dev.java.net/OpenDS.LICENSE. * See the License for the specific language governing permissions * and limitations under the License. * * When distributing Covered Code, include this CDDL HEADER in each * file and include the License file at * trunk/opends/resource/legal-notices/OpenDS.LICENSE. If applicable, * add the following below this CDDL HEADER, with the fields enclosed * by brackets "[]" replaced with your own identifying information: * Portions Copyright [yyyy] [name of copyright owner] * * CDDL HEADER END * * * Portions Copyright 2007 Sun Microsystems, Inc. */ package org.opends.quicksetup.upgrader; import org.opends.quicksetup.*; import org.opends.quicksetup.event.ProgressUpdateListener; import org.opends.quicksetup.event.ProgressUpdateEvent; import org.opends.quicksetup.util.Utils; import org.opends.quicksetup.util.ZipExtractor; import org.opends.quicksetup.util.FileManager; import org.opends.quicksetup.util.PlainTextProgressMessageFormatter; import java.io.File; import java.io.IOException; import java.io.FileNotFoundException; import java.util.logging.Level; import java.util.logging.Logger; /** * BuildExtractor unzips an OpenDS installation package (.zip file) from a user * specified location into the current builds staging directory. This Java * program handles this task so that we don't need to rely on the operating * system's tools for managing zip files. * * This tool is a stand-alone program since it is run in preparation for a * off line upgrade and runs using the current program's jars rather than * the new build's jars as is manditory for the Upgrader itself. Since this * tool itself is run using the old bits prior to upgrade and the upgrade * itself is dependent upon this tool, it should be kept simple and stable * to insure that the upgrade will work. */ public class BuildExtractor extends Application implements Runnable { static private final Logger LOG = Logger.getLogger(BuildExtractor.class.getName()); /** * Creates and run a BuildExtractor using command line arguments. * @param args String[] command line arguments */ public static void main(String[] args) { try { QuickSetupLog.initLogFileHandler( File.createTempFile( UpgradeLauncher.LOG_FILE_PREFIX + "ext-", UpgradeLauncher.LOG_FILE_SUFFIX)); } catch (Throwable t) { System.err.println("Unable to initialize log"); t.printStackTrace(); } new BuildExtractor(args).run(); } private String[] args = null; private boolean finished = false; private BuildExtractor(String[] args) { this.args = args; setProgressMessageFormatter(new PlainTextProgressMessageFormatter()); addProgressUpdateListener(new ProgressUpdateListener() { public void progressUpdate(ProgressUpdateEvent ev) { System.out.println(ev.getNewLogs()); } }); } /** * Executes this build extractor. First and attempt is made to extract the * build file name from the command line arguments. If no such file has been * specified this program simply exits with a return code of 0. If such a * file has been specified this program performs a certain amount of * verification on the file. If the verification fails this program prints * a message and exits with with a return code of 1 meaning that the upgrade * process should end. If verification succeeeds this program unzips its * contents into the current build's staging are and exits with return code 0. */ public void run() { int retCode = 0; try { File buildFile = getBuildFile(args); if (buildFile != null) { if (!buildFile.exists()) { // TODO: i18n throw new FileNotFoundException( buildFile.getName() + " does not exist"); } expandZipFile(buildFile); } } catch (Throwable t) { LOG.log(Level.INFO, "unexpected error extracting build", t); retCode = 1; } LOG.log(Level.INFO, "extractor exiting code=" + retCode); System.exit(retCode); } private File getBuildFile(String[] args) { File buildFile = null; String buildFileName = null; if (args != null) { for (int i = 0; i < args.length; i++) { if (args[i].equals("--" + UpgraderCliHelper.FILE_OPTION_LONG) || args[i].equalsIgnoreCase( "-" + UpgraderCliHelper.FILE_OPTION_SHORT)) { if (i < args.length - 1) { buildFileName = args[i+ 1]; } } } } if (buildFileName != null) { buildFile = new File(buildFileName); } return buildFile; } private void expandZipFile(File buildFile) throws ApplicationException, IOException { try { LOG.log(Level.INFO, "expanding zip file " + buildFile.getPath()); ZipExtractor extractor = new ZipExtractor(buildFile); extractor.extract(getStageDirectory()); LOG.log(Level.INFO, "extraction finished"); } finally { finished = true; } } private File getStageDirectory() throws ApplicationException { File stageDir; Installation installation = new Installation(getInstallationPath()); stageDir = installation.getTemporaryUpgradeDirectory(); if (stageDir.exists()) { FileManager fm = new FileManager(); fm.deleteRecursively(stageDir); } if (!stageDir.mkdirs()) { // TODO: i18n throw ApplicationException.createFileSystemException( "failed to create staging directory " + stageDir, null); } LOG.log(Level.INFO, "stage directory " + stageDir.getPath()); return stageDir; } /** * {@inheritDoc} */ protected String getInstallationPath() { return Utils.getInstallPathFromClasspath(); } /** * {@inheritDoc} */ public ProgressStep getCurrentProgressStep() { return null; } /** * {@inheritDoc} */ public Integer getRatio(ProgressStep step) { return null; } /** * {@inheritDoc} */ public String getSummary(ProgressStep step) { return null; } /** * {@inheritDoc} */ public boolean isFinished() { return finished; } }