autohit.common.deployment.DeploymentConfigure.java Source code

Java tutorial

Introduction

Here is the source code for autohit.common.deployment.DeploymentConfigure.java

Source

/**
 * AUTOHIT 2003
 * Copyright Erich P Gatejen (c) 1989,1997,2003,2004
 * 
 * This program is free software; you can redistribute it and/or modify 
 * it under the terms of the GNU General Public License as published by 
 * the Free Software Foundation; either version 2 of the License, or (at
 * your option) any later version.
 * This program is distributed in the hope that it will be useful, but
 * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
 * or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
 * more details.
 * 
 * You should have received a copy of the GNU General Public License along
 * with this program; if not, write to the Free Software Foundation, Inc.,
 * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
 *
 * Additional license information can be found in the documentation.
 * @author Erich P Gatejen
 */
package autohit.common.deployment;

import java.io.BufferedReader;
import java.io.File;
import java.io.FileReader;
import java.util.StringTokenizer;

import org.apache.commons.collections.ExtendedProperties;

import autohit.common.AutohitProperties;
import autohit.common.Constants;
import autohit.common.Utils;

/**
 * A deployment manager.  It will handle configuration, installation, and checkpointing.
 *
 * @author Erich P. Gatejen
 * @version 1.0
 * <i>Version History</i>
 * <code>EPG - Initial - 25Apr03 
 * 
 */
public class DeploymentConfigure {

    /**
     * Command system
     */
    public ExtendedProperties props;

    /**
     *  Default constructor. 
     */
    public DeploymentConfigure() throws Exception {

    }

    /**
     *  Checkpoint the system
     * @param name checkpoint name
     * @param root directory root
     * @param cf configuration file
     * @param special unlock factory.  ALWAYS use FALSE
     * @return true if successful, false if there is an error
     */
    public boolean checkpoint(String name, String root, String cf, boolean special) {

        String[] currentLine;
        String lf;
        File lFile;
        int count = 0;
        int lineCount = 0;

        // Is it trying to checkpoint to the factory settings?
        if ((special == false) && (name.equals(AutohitProperties.vFACTORY_STORE))) {
            System.out.println(
                    "You may not checkpoint to the factory settings.  Use a checkpoint name other than 'factory'.");
            return false;
        }

        String configPath = new String(root + AutohitProperties.vCONFIG_ROOT + name + "/");

        // See if already saved.
        File fdpath = new File(configPath);
        if (fdpath.exists()) {
            System.out.println("There is already a " + name + " checkpoint set.");
            System.out.println("You can use the delete command to remove it.");
            return false;
        }

        // Set the config file
        if (cf == null) {
            cf = AutohitProperties.vDEFAULT_CHECKPOINT;
        }
        lf = new String(root + AutohitProperties.vCONFIG_ROOT + cf);

        // Get to work      
        try {
            // Make the dir
            fdpath.mkdirs();

            // Open config file
            lFile = new File(lf);
            BufferedReader inBR = new BufferedReader(new FileReader(lFile));

            // example line: n bin/default.prop factory/standard/default.prop
            currentLine = parseConfigLine(inBR);
            while (currentLine != null) {
                lineCount++;
                switch (currentLine[0].charAt(0)) {

                case Constants.CONFIG_DIR:
                    System.out.println(Utils.copyDir(root + "/" + currentLine[1],
                            configPath + Integer.toString(count), false));
                    count++;
                    break;

                case Constants.CONFIG_COMMENT:
                    // ignore
                    break;

                case Constants.CONFIG_CHKPNT:
                case Constants.CONFIG_CONFIG_YES:
                case Constants.CONFIG_CONFIG_NO:
                    System.out
                            .println(Utils.copy(root + "/" + currentLine[1], configPath + Integer.toString(count)));
                    count++;
                    break;

                default:
                    System.out.println(
                            "Bad command.  Line #" + lineCount + ".  Command =" + currentLine[0].charAt(0));
                }
                currentLine = parseConfigLine(inBR);
            }

            // Move the config file
            inBR.close();
            System.out.println(Utils.copy(lf, configPath + AutohitProperties.vCONFIG_FILE));

        } catch (Exception e) {
            System.out.println("CHECKPOINT failed!");
            e.printStackTrace();
            return false;
        }

        System.out.println("CHECKPOINT is done.");
        return true;
    }

    /**
     * Delete a checkpoint
     * @param name checkpoint name
     * @param root directory root
     * @return true if successful, false if there is an error
     */
    public boolean delete(String name, String root) {

        String[] currentLine;
        String lf;
        File lFile;
        int count = 0;
        int lineCount = 0;

        String configPath = new String(root + AutohitProperties.vCONFIG_ROOT + name);

        // Is it trying to remove the factory settings?
        if (name.equals(AutohitProperties.vFACTORY_STORE)) {
            System.out.println("You may not delete the factory settings.");
        }

        // See if already saved.
        File fdpath = new File(configPath);
        if (!fdpath.exists()) {
            System.out.println("Checkpoint set does not exist.");
            return false;
        }

        System.out.println(Utils.wipeDir(configPath));
        System.out.println("DELETE is done.  Check messages for errors.");
        return true;
    }

    /**
     *  Restore a checkpoint
     * @param name checkpoint name
     * @param root directory root
     * @param wipe destructive restore
     * @return true if successful, false if there is an error
     */
    public boolean restore(String name, String root, boolean wipe) {

        String[] currentLine;
        String lf;
        File fdfile;
        int count = 0;
        int lineCount = 0;
        BufferedReader inBR;

        String configPath = new String(root + AutohitProperties.vCONFIG_ROOT + name + "/");
        String configFile = new String(configPath + AutohitProperties.vCONFIG_FILE);

        // See if it is there and get the configuration file
        try {

            fdfile = new File(configPath);
            if (!fdfile.exists())
                throw new Exception();
            inBR = new BufferedReader(new FileReader(fdfile));

        } catch (Exception e) {
            System.out.println("Checkpoint does not exist or is invalid for " + name);
            return false;
        }

        // Get to work      
        try {

            // example line: n bin/default.prop factory/standard/default.prop
            currentLine = parseConfigLine(inBR);
            while (currentLine != null) {
                lineCount++;
                switch (currentLine[1].charAt(0)) {

                case Constants.CONFIG_DIR:
                    System.out.println(
                            Utils.copyDir(configPath + Integer.toString(count), root + "/" + currentLine[1], wipe));
                    count++;
                    break;

                case Constants.CONFIG_COMMENT:
                    // ignore
                    break;

                case Constants.CONFIG_CHKPNT:
                case Constants.CONFIG_CONFIG_YES:
                case Constants.CONFIG_CONFIG_NO:
                    System.out
                            .println(Utils.copy(root + "/" + currentLine[1], configPath + Integer.toString(count)));
                    count++;
                    break;

                default:
                    System.out.println(
                            "Bad command.  Line #" + lineCount + ".  Command =" + currentLine[1].charAt(0));
                }
                currentLine = parseConfigLine(inBR);
            }

        } catch (Exception e) {
            System.out.println("RESTORE failed!");
            e.printStackTrace();
            return false;
        }
        System.out.println("RESTORE is done.");
        return true;
    }

    /**config config [config name] [root] [prop file]
     * Process a configuration
     * @param config config file name
     * @param root directory root
     * @param vars variable replacement set.  a properties file.
     * @return true if successful, false if there is an error
     */
    public boolean configure(String config, String root, String vars) {

        ExtendedProperties varprops;

        // Get variables file and load into varprops
        String varPath = new String(root + AutohitProperties.vVAR_ROOT + vars);
        File varFile = new File(varPath);
        if (!varFile.exists()) {
            System.out.println("Configuration values file does not exist= " + vars
                    + ".  It should be under the /etc directory.");
            return false;
        }
        try {
            varprops = new ExtendedProperties(varPath);
        } catch (Exception e) {
            System.out.println("Configuration values file is unreadable.");
            return false;
        }
        return configure(config, root, varprops);
    }

    /**config config [config name] [root] [prop file]
     * Process a configuration
     * @param config config file name
     * @param root directory root
     * @param varprops an ExtendedProperties set of configuration name/values.
     * @return true if successful, false if there is an error
     */
    public boolean configure(String config, String root, ExtendedProperties varprops) {

        String[] currentLine;
        String lf;
        File fdfile;
        int count = 0;
        int lineCount = 0;
        BufferedReader inBR;

        String configPath;
        String configPathFile;
        File fConfigFile;

        // See if it is there and get the configuration file
        try {
            // try the root
            configPath = new String(root + AutohitProperties.vCONFIG_ROOT + config + "/");
            configPathFile = new String(configPath + AutohitProperties.vCONFIG_FILE);
            fConfigFile = new File(configPathFile);
            if (!fConfigFile.exists()) {
                // see if there are any hanger-ons
                configPathFile = new String(configPath + config);
                fConfigFile = new File(configPathFile);
                if (!fConfigFile.exists())
                    throw new Exception();
            }
            inBR = new BufferedReader(new FileReader(fConfigFile));
        } catch (Exception e) {
            System.out.println("Configuration descriptor is invalid for " + config);
            return false;
        }

        // Get to work      
        try {

            // example line: n bin/default.prop factory/standard/default.prop
            currentLine = parseConfigLine(inBR);
            while (currentLine != null) {
                lineCount++;
                System.out.println("linecount=" + lineCount + " count=" + count + " line=" + currentLine[0]);
                switch (currentLine[0].charAt(0)) {

                case Constants.CONFIG_DIR:
                    System.out.println(Utils.copyDir(configPath + Integer.toString(count),
                            root + "/" + currentLine[1], false));
                    count++;
                    break;

                case Constants.CONFIG_COMMENT:
                case Constants.CONFIG_CHKPNT:
                    // ignore
                    break;

                case Constants.CONFIG_CONFIG_YES:
                    System.out.println(Utils.merge(configPath + Integer.toString(count),
                            root + "/" + currentLine[1], varprops));
                    count++;
                    break;

                case Constants.CONFIG_CONFIG_NO:
                    System.out
                            .println(Utils.copy(configPath + Integer.toString(count), root + "/" + currentLine[1]));
                    count++;
                    break;

                default:
                    System.out.println(
                            "Bad command.  Line #" + lineCount + ".  Command =" + currentLine[0].charAt(0));
                }
                currentLine = parseConfigLine(inBR);
            }

        } catch (Exception e) {
            System.out.println("CONFIGURE failed!");
            e.printStackTrace();
            return false;
        }
        System.out.println("CONFIGURE is done.");
        return true;
    }

    /**
     *  Parse the config line
     */
    private String[] parseConfigLine(BufferedReader inR) {

        String t[] = new String[3];
        String working = null;
        StringTokenizer st;

        try {

            working = inR.readLine();
            while ((working.length() == 0) || (working.charAt(0) == '#')
                    || (!Character.isLetter(working.charAt(0)))) {
                working = inR.readLine();
            }

            // Working should be a valid line
            try {

                st = new StringTokenizer(working);
                t[0] = st.nextToken();
                t[1] = st.nextToken();
                // the third field doesn't matter for checkpointing
                try {
                    t[2] = st.nextToken();
                } catch (Exception e) {
                    t[2] = null;
                }

            } catch (Exception e) {
                System.out.println("BAD line in Files:\n" + working);
                throw e;
            }

        } catch (Exception e) {
            // Quit for ANY exception
            return null;
        }

        return t;
    }

    /**
     *  Object main
     */
    public void go(String[] args) {

        char cmd = args[0].charAt(0);
        switch (cmd) {
        case 'S':
        case 's':
            if (args.length == 4) {
                checkpoint(args[1], args[2], args[3], false);
            } else if (args.length == 3) {
                checkpoint(args[1], args[2], null, false);
            } else {
                System.out.println("ERROR: Bad number of parameters.");
                usage();
            }
            break;

        case 'F':
        case 'f':
            System.out.println("BUILD FACTORY SETTINGS");
            // CHECKPOINT THE FACTORY
            // YOU SHOULDN'T DO THIS!  IT'S FOR THE BUILD SYSTEM
            // The command is "config factory PLEASE [root]" (cases sensitive)
            if ((args.length == 3) && (args[1].charAt(0) == 'P')) {
                checkpoint(AutohitProperties.vFACTORY_STORE, args[2], AutohitProperties.vDEFAULT_CHECKPOINT, true);
            } else {
                System.out.println("ERROR: Unknown command.");
                usage();
            }
            break;

        case 'R':
        case 'r':
            if (args.length == 3) {
                restore(args[1], args[2], true);
            } else {
                System.out.println("ERROR: Bad number of parameters.");
                usage();
            }
            break;
        case 'M':
        case 'm':
            if (args.length == 3) {
                restore(args[1], args[2], false);
            } else {
                System.out.println("ERROR: Bad number of parameters.");
                usage();
            }
            break;
        case 'D':
        case 'd':
            if (args.length == 3) {
                delete(args[1], args[2]);
            } else {
                System.out.println("ERROR: Bad number of parameters.");
                usage();
            }

            break;
        case 'c':
        case 'C':
            if (args.length != 4) {
                System.out.println("ERROR: Bad parameters.");
            } else {
                configure(args[1], args[2], args[3]);
            }
            break;

        case 'H':
        case 'h':
        case '?':
        case '-':
            usage();
            break;

        default:
            System.out.println("ERROR: Unknown command.");
            usage();
            break;
        }
    }

    // Usage
    public void usage() {
        System.out.println("Deployment Configuration for Autohit (2003):");
        System.out.println("  config config [name] [root] [var file]");
        System.out.println("  config save [name] [root] (config file)");
        System.out.println("  ...... save a checkpoint by name.");
        System.out.println("  config delete [name] [root]");
        System.out.println("  config restore [name] [root]");
        System.out.println("  ...... restore a checkpoint.  It is destructive.");
        System.out.println("  config merge [name] [root]");
        System.out.println("  ...... merge a checkpoint.  It will only overwrite named files.");
        System.out.println("  The configuration called 'factory' will restore to the system to");
        System.out.println("  ...... out-of-the-box.");
    }

    /**
     * main interface
     */
    public static void main(String[] args) {

        try {
            DeploymentConfigure me = new DeploymentConfigure();

            // handle arguments
            if (args.length == 0) {
                System.out.println("Huh?  What did you want me to do?");
                me.usage();
                return;
            }

            me.go(args);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}