All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.xebialabs.overthere.ConnectionOptions Maven / Gradle / Ivy

There is a newer version: 5.6.16
Show newest version
/*
 * Copyright (c) 2008-2014, XebiaLabs B.V., All rights reserved.
 *
 *
 * Overthere is licensed under the terms of the GPLv2
 * , like most XebiaLabs Libraries.
 * There are special exceptions to the terms and conditions of the GPLv2 as it is applied to
 * this software, see the FLOSS License Exception
 * .
 *
 * 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; version 2
 * of the License.
 *
 * 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., 51 Franklin St, Fifth
 * Floor, Boston, MA 02110-1301  USA
 */
package com.xebialabs.overthere;

import java.util.*;

import static com.xebialabs.overthere.ssh.SshConnectionBuilder.PASSPHRASE;
import static com.xebialabs.overthere.ssh.SshConnectionBuilder.PRIVATE_KEY;

/**
 * Represents options to use when creating a {@link OverthereConnection connection}.
 */
public class ConnectionOptions {

    /**
     * See the online documentation
     */
    public static final String OPERATING_SYSTEM = "os";

    /**
     * See the online documentation
     */
    public static final String TEMPORARY_DIRECTORY_PATH = "tmp";

    /**
     * See the online documentation
     */
    public static final String TEMPORARY_DIRECTORY_DELETE_ON_DISCONNECT = "tmpDeleteOnDisconnect";

    /**
     * See the online documentation
     */
    public static final boolean TEMPORARY_DIRECTORY_DELETE_ON_DISCONNECT_DEFAULT = true;

    /**
     * See the online documentation
     */
    public static final String TEMPORARY_FILE_CREATION_RETRIES = "tmpFileCreationRetries";

    /**
     * See the online documentation
     */
    public static final int TEMPORARY_FILE_CREATION_RETRIES_DEFAULT = 100;

    /**
     * See the online documentation
     */
    public static final String CONNECTION_TIMEOUT_MILLIS = "connectionTimeoutMillis";

    /**
     * See the online documentation
     */
    public static final int CONNECTION_TIMEOUT_MILLIS_DEFAULT = 120000;

    /**
     * See the online documentation
     */
    public static final String ADDRESS = "address";

    /**
     * See the online documentation
     */
    public static final String PORT = "port";

    /**
     * See the online documentation
     */
    public static final String USERNAME = "username";

    /**
     * See the online documentation
     */
    public static final String PASSWORD = "password";

    /**
     * See the online documentation
     */
    public static final String JUMPSTATION = "jumpstation";

    /**
     * See the online documentation
     */
    public static final String FILE_COPY_COMMAND_FOR_UNIX = "fileCopyCommandForUnix";

    /**
     * See the online documentation
     */
    public static final String FILE_COPY_COMMAND_FOR_UNIX_DEFAULT = "cp -p {0} {1}";

    /**
     * See the online documentation
     */
    public static final String DIRECTORY_COPY_COMMAND_FOR_UNIX = "directoryCopyCommandForUnix";

    /**
     * See the online documentation
     */
    public static final String DIRECTORY_COPY_COMMAND_FOR_UNIX_DEFAULT = "cd {1} ; tar -cf - -C {0} . | tar xpf -";

    /**
     * See the online documentation
     */
    public static final String FILE_COPY_COMMAND_FOR_WINDOWS = "fileCopyCommandForWindows";

    /**
     * See the online documentation
     */
    public static final String FILE_COPY_COMMAND_FOR_WINDOWS_DEFAULT = "copy {0} {1} /y";

    /**
     * See the online documentation
     */
    public static final String DIRECTORY_COPY_COMMAND_FOR_WINDOWS = "directoryCopyCommandForWindows";

    /**
     * See the online documentation
     */
    public static final String DIRECTORY_COPY_COMMAND_FOR_WINDOWS_DEFAULT = "xcopy {0} {1} /i /y /s /e /h /q";

    /**
     * See the online documentation
     */
    public static final String FILE_COPY_COMMAND_FOR_ZOS = "fileCopyCommandForZos";

    /**
     * See the online documentation
     */
    public static final String FILE_COPY_COMMAND_FOR_ZOS_DEFAULT = "cp -p {0} {1}";

    /**
     * See the online documentation
     */
    public static final String DIRECTORY_COPY_COMMAND_FOR_ZOS = "directoryCopyCommandForZos";

    /**
     * See the online documentation
     */
    public static final String DIRECTORY_COPY_COMMAND_FOR_ZOS_DEFAULT = "tar cC {0} . | tar xmC {1}";

    /**
     * See the online documentation
     */
    public static final String REMOTE_COPY_BUFFER_SIZE = "remoteCopyBufferSize";

    /**
     * See the online documentation
     */
    public static final int REMOTE_COPY_BUFFER_SIZE_DEFAULT = 64 * 1024; // 64 KB

    private final Map options;

    private static final Set filteredKeys = getFilteredKeys();

    private static Set getFilteredKeys() {
        HashSet strings = new HashSet();
        strings.add(PASSWORD);
        strings.add(PASSPHRASE);
        strings.add(PRIVATE_KEY);
        return Collections.unmodifiableSet(strings);
    }

    /**
     * Creates an empty options object.
     */
    public ConnectionOptions() {
        options = new HashMap();
    }

    /**
     * Creates a copy of an existing options object.
     */
    public ConnectionOptions(ConnectionOptions options) {
        this();
        this.options.putAll(options.options);
    }

    /**
     * Sets a connection option.
     *
     * @param key   the key of the connection option.
     * @param value the value of the connection option.
     */
    public void set(String key, Object value) {
        options.put(key, value);
    }

    /**
     * Retrieves the value of a required connection option.
     *
     * @param  the type of the connection option.
     * @param key the key of the connection option.
     * @return the value of the connection option.
     * @throws IllegalArgumentException if no value was supplied for the connection option
     */
    @SuppressWarnings("unchecked")
    public  T get(String key) throws IllegalArgumentException {
        T value = (T) options.get(key);
        if (value == null) {
            throw new IllegalArgumentException("No value specified for required connection option " + key);
        }
        return value;
    }

    /**
     * Retrieves the value of an optional connection option.
     *
     * @param  the type of the connection option.
     * @param key the key of the connection option.
     * @return the value of the connection option or null if that option was not specified.
     */
    @SuppressWarnings("unchecked")
    public  T getOptional(String key) {
        return (T) options.get(key);
    }

    /**
     * Retrieves the value of a connection option or a default value if that option has not been set.
     *
     * @param           the type of the connection option.
     * @param key          the key of the connection option.
     * @param defaultValue the default value to use of the connection options has not been set.
     * @return the value of the connection option or the default value if that option was not specified.
     */
    @SuppressWarnings("unchecked")
    public  T get(String key, T defaultValue) {
        if (options.containsKey(key)) {
            return (T) options.get(key);
        } else {
            return defaultValue;
        }
    }

    public boolean getBoolean(String key) {
        Object o = options.get(key);
        if (o == null) {
            throw new IllegalArgumentException("No value specified for required connection option " + key);
        } else if (o instanceof Boolean) {
            return (Boolean) o;
        } else if (o instanceof String) {
            return Boolean.valueOf((String) o);
        } else {
            throw new IllegalArgumentException("Value specified for required connection option " + key + " is neither a Boolean nor a String");
        }
    }

    public boolean getBoolean(String key, boolean defaultValue) {
        Object o = options.get(key);
        if (o == null) {
            return defaultValue;
        } else if (o instanceof Boolean) {
            return (Boolean) o;
        } else if (o instanceof String) {
            return Boolean.valueOf((String) o);
        } else {
            throw new IllegalArgumentException("Value specified for connection option " + key + " is neither a Boolean nor a String");
        }
    }

    public int getInteger(String key) {
        Object o = options.get(key);
        if (o == null) {
            throw new IllegalArgumentException("No value specified for required connection option " + key);
        } else if (o instanceof Integer) {
            return (Integer) o;
        } else if (o instanceof String) {
            return Integer.parseInt((String) o);
        } else {
            throw new IllegalArgumentException("Value specified for required connection option " + key + " is neither an Integer nor a String");
        }
    }

    public int getInteger(String key, int defaultValue) {
        Object o = options.get(key);
        if (o == null) {
            return defaultValue;
        } else if (o instanceof Integer) {
            return (Integer) o;
        } else if (o instanceof String) {
            return Integer.parseInt((String) o);
        } else {
            throw new IllegalArgumentException("Value specified for connection option " + key + " is neither an Integer nor a String");
        }
    }

    @SuppressWarnings("unchecked")
    public > T getEnum(String key, Class enumClazz) {
        Object o = options.get(key);
        if (o == null) {
            throw new IllegalArgumentException("No value specified for required connection option " + key);
        } else if (o.getClass().equals(enumClazz)) {
            return (T) o;
        } else if (o instanceof String) {
            return Enum.valueOf(enumClazz, (String) o);
        } else {
            throw new IllegalArgumentException("Value specified for required connection option " + key + " is neither an " + enumClazz.getName()
                    + " nor a String");
        }
    }

    @SuppressWarnings("unchecked")
    public > T getEnum(String key, Class enumClazz, T defaultValue) {
        Object o = options.get(key);
        if (o == null) {
            return defaultValue;
        } else if (o.getClass().equals(enumClazz)) {
            return (T) o;
        } else if (o instanceof String) {
            return Enum.valueOf(enumClazz, (String) o);
        } else {
            throw new IllegalArgumentException("Value specified for connection option " + key + " is neither an instanceof of " + enumClazz.getName()
                    + " nor a String");
        }
    }

    /**
     * Returns whether a connection option is set.
     *
     * @param key the key of the connection option.
     * @return true iff the connection option is set, false otherwise.
     */
    public boolean containsKey(String key) {
        return options.containsKey(key);
    }

    /**
     * Returns the keys of all connection options set.
     *
     * @return a {@link Set} containing the keys.
     */
    public Set keys() {
        return options.keySet();
    }

    @Override
    public boolean equals(Object o) {
        if (this == o)
            return true;
        if (o == null || getClass() != o.getClass())
            return false;

        ConnectionOptions that = (ConnectionOptions) o;

        return options.equals(that.options);

    }

    @Override
    public int hashCode() {
        return options.hashCode();
    }

    @Override
    public String toString() {
        return print(this, "");
    }

    private static String print(ConnectionOptions options, String indent) {
        StringBuilder b = new StringBuilder();
        b.append("ConnectionOptions[\n");
        for (Map.Entry e : options.options.entrySet()) {
            b.append(indent).append("\t").append(e.getKey()).append(" --> ");
            Object value = e.getValue();
            if (value instanceof ConnectionOptions) {
                b.append(print((ConnectionOptions) value, indent + "\t"));
            } else {
                b.append(filteredKeys.contains(e.getKey()) ? "********" : value);
            }
            b.append("\n");
        }
        b.append(indent).append("]");
        return b.toString();
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy