Package voldemort.utils.app

Source Code of voldemort.utils.app.VoldemortApp

/*
* Copyright 2009 LinkedIn, Inc.
*
* Licensed under the Apache License, Version 2.0 (the "License"); you may not
* use this file except in compliance with the License. You may obtain a copy of
* the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
* WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
* License for the specific language governing permissions and limitations under
* the License.
*/

package voldemort.utils.app;

import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.Enumeration;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Properties;

import joptsimple.OptionException;
import joptsimple.OptionParser;
import joptsimple.OptionSet;

import org.apache.commons.io.FileUtils;
import org.apache.commons.io.IOUtils;
import org.apache.commons.io.LineIterator;
import org.apache.commons.lang.StringUtils;
import org.apache.log4j.Level;
import org.apache.log4j.Logger;

import voldemort.utils.CmdUtils;
import voldemort.utils.HostNamePair;

import com.xerox.amazonws.ec2.RegionInfo;

@SuppressWarnings("unchecked")
public abstract class VoldemortApp {

    protected final OptionParser parser = new OptionParser();

    protected abstract String getScriptName();

    protected abstract void run(String[] args) throws Exception;

    protected void printUsage() {
        System.err.println("Usage: $VOLDEMORT_HOME/contrib/ec2-testing/bin/" + getScriptName());

        try {
            parser.printHelpOn(System.err);
        } catch(IOException e) {
            e.printStackTrace();
        }

        System.exit(1);
    }

    protected OptionSet parse(String[] args) {
        try {
            OptionSet options = parser.parse(args);

            if(options.has("help"))
                printUsage();

            setLogging(options);
            return options;
        } catch(OptionException e) {
            System.err.println(e.getMessage());
            printUsage();
            return null;
        }
    }

    protected void setLogging(OptionSet options) {
        // "Options are \"debug\", \"info\" (default), \"warn\", \"error\", or \"off\"")
        String levelString = CmdUtils.valueOf(options, "logging", "info");

        Level level = null;

        if(levelString.equals("debug"))
            level = Level.DEBUG;
        else if(levelString.equals("info"))
            level = Level.INFO;
        else if(levelString.equals("warn"))
            level = Level.WARN;
        else if(levelString.equals("error"))
            level = Level.ERROR;
        else if(levelString.equals("off"))
            level = Level.OFF;
        else
            printUsage();

        Logger rootLogger = Logger.getRootLogger();
        rootLogger.setLevel(level);

        Enumeration<Logger> e = rootLogger.getLoggerRepository().getCurrentLoggers();

        while(e.hasMoreElements()) {
            Logger logger = e.nextElement();
            logger.setLevel(level);
        }
    }

    protected String getRequiredString(OptionSet options, String argumentName) {
        if(!options.has(argumentName)) {
            System.err.println("Missing required argument " + argumentName);
            printUsage();
        }

        return CmdUtils.valueOf(options, argumentName, "");
    }

    protected int getRequiredInt(OptionSet options, String argumentName) {
        if(!options.has(argumentName)) {
            System.err.println("Missing required argument " + argumentName);
            printUsage();
        }

        return CmdUtils.valueOf(options, argumentName, 0);
    }

    protected long getRequiredLong(OptionSet options, String argumentName) {
        if(!options.has(argumentName)) {
            System.err.println("Missing required argument " + argumentName);
            printUsage();
        }

        return Long.parseLong(CmdUtils.valueOf(options, argumentName, "0"));
    }

    protected File getRequiredInputFile(OptionSet options, String argumentName) {
        String fileName = getRequiredString(options, argumentName);
        File file = new File(fileName);

        if(!file.canRead()) {
            System.err.println("File " + fileName + " cannot be read");
            System.exit(2);
        }

        return file;
    }

    protected List<File> getRequiredInputFiles(OptionSet options, String argumentName) {
        List<String> fileNames = (List<String>) options.valuesOf(argumentName);
        List<File> returnFileList = new ArrayList<File>();
        for(String name: fileNames) {
            File file = new File(name);
            if(file.canRead()) {
                returnFileList.add(file);
            }
        }

        return returnFileList;
    }

    protected File getInputFile(OptionSet options, String argumentName) {
        if(!options.has(argumentName))
            return null;

        String fileName = CmdUtils.valueOf(options, argumentName, "");
        File file = new File(fileName);

        if(!file.canRead()) {
            System.err.println("File " + fileName + " cannot be read");
            System.exit(2);
        }

        return file;
    }

    protected List<HostNamePair> getHostNamesPairsFromFile(File file) {
        List<HostNamePair> hostNamePairs = new ArrayList<HostNamePair>();

        // This was recently changed from using Properties to performing the
        // file parsing manually. This is due to the fact that we want to
        // maintain the ordering in the file. Line N in the host names file
        // should correspond to node ID N-1. Previously they were in hashed
        // order, so certain tools that auto-configure a cluster based on
        // this same hosts file were creating invalid configurations between
        // the cluster.xml and server.properties (node.id) files.
        LineIterator li = null;
        int lineNumber = 0;

        try {
            li = FileUtils.lineIterator(file);

            while(li.hasNext()) {
                String rawLine = String.valueOf(li.next()).trim();
                lineNumber++;

                // Strip comments
                int hashIndex = rawLine.indexOf("#");

                if(hashIndex != -1)
                    rawLine = rawLine.substring(0, hashIndex).trim();

                // Whitespace
                if(rawLine.length() == 0)
                    continue;

                String[] line = StringUtils.split(rawLine, " \t=:");

                if(line.length < 1 || line.length > 2) {
                    System.err.println("Invalid entry (line " + lineNumber + ") in "
                                       + file.getAbsolutePath() + ": " + rawLine);
                    System.exit(2);
                }

                String externalHostName = line[0];
                String internalHostName = line.length > 1 ? line[1] : externalHostName;
                hostNamePairs.add(new HostNamePair(externalHostName, internalHostName));
            }
        } catch(IOException e) {
            throw new RuntimeException(e);
        } finally {
            if(li != null)
                li.close();
        }

        return hostNamePairs;
    }

    protected Map<String, String> getRequiredPropertiesFile(File file) {
        if(!file.canRead()) {
            System.err.println("File " + file.getAbsolutePath() + " cannot be read");
            System.exit(2);
        }

        Properties properties = new Properties();
        InputStream is = null;

        try {
            is = new FileInputStream(file);
            properties.load(is);
        } catch(IOException e) {
            throw new RuntimeException(e);
        } finally {
            IOUtils.closeQuietly(is);
        }

        Map<String, String> map = new HashMap<String, String>();

        for(Map.Entry<Object, Object> entry: properties.entrySet()) {
            String key = entry.getKey() != null ? entry.getKey().toString() : null;
            String value = entry.getValue() != null ? entry.getValue().toString() : null;

            map.put(key, value);
        }

        return map;
    }

    protected String getRegionUrl(OptionSet options) throws Exception {
        if(options.has("region")) {
            return CmdUtils.valueOf(options, "region", RegionInfo.REGIONURL_US_EAST);
        } else {
            return RegionInfo.REGIONURL_US_EAST;
        }
    }

    protected String getAccessId(OptionSet options) throws Exception {
        if(!options.has("accessid") && !options.has("accessidfile")) {
            System.err.println("Missing required argument accessid or accessidfile");
            printUsage();
        } else if(options.has("accessid") && options.has("accessidfile")) {
            System.err.println("Provide either accessid or accessidfile, not both");
            printUsage();
        } else if(options.has("accessid")) {
            return CmdUtils.valueOf(options, "accessid", "");
        } else {
            File file = new File(CmdUtils.valueOf(options, "accessidfile", ""));
            return FileUtils.readFileToString(file).trim();
        }

        return null;
    }

    protected String getSecretKey(OptionSet options) throws Exception {
        if(!options.has("secretkey") && !options.has("secretkeyfile")) {
            System.err.println("Missing required argument secretkey or secretkeyfile");
            printUsage();
        } else if(options.has("secretkey") && options.has("secretkeyfile")) {
            System.err.println("Provide either secretkey or secretkeyfile, not both");
            printUsage();
        } else if(options.has("secretkey")) {
            return CmdUtils.valueOf(options, "secretkey", "");
        } else {
            File file = new File(CmdUtils.valueOf(options, "secretkeyfile", ""));
            return FileUtils.readFileToString(file).trim();
        }

        return null;
    }

    protected List<Integer> getRequiredListIntegers(OptionSet options, String argumentName)
            throws Exception {
        if(!options.has(argumentName)) {
            System.err.println("Missing required argument " + argumentName);
            printUsage();
        }
        return (List<Integer>) options.valuesOf(argumentName);
    }

}
TOP

Related Classes of voldemort.utils.app.VoldemortApp

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.