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

org.apacheextras.camel.component.virtualbox.command.MachineAwareVirtualBoxCommand Maven / Gradle / Ivy

/**************************************************************************************
 https://camel-extra.github.io

 This program is free software; you can redistribute it and/or
 modify it under the terms of the GNU Lesser General Public License
 as published by the Free Software Foundation; either version 3
 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 Lesser General Public License for more details.


 You should have received a copy of the GNU Lesser General Public
 License along with this program; if not, write to the Free Software
 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
 02110-1301, USA.

 http://www.gnu.org/licenses/lgpl-3.0-standalone.html
 ***************************************************************************************/
package org.apacheextras.camel.component.virtualbox.command;

import org.apache.camel.Exchange;
import org.slf4j.Logger;

import static org.slf4j.LoggerFactory.getLogger;

public abstract class MachineAwareVirtualBoxCommand implements VirtualBoxCommand {

    private final static Logger LOG = getLogger(MachineAwareVirtualBoxCommand.class);

    public static final String HEADER_MACHINE = "virtualbox_machine";

    protected final String machineName;

    protected MachineAwareVirtualBoxCommand(String machineName) {
        this.machineName = machineName;
    }

    public String machineName() {
        return machineName;
    }

    public static String resolveMachineId(Exchange exchange, String defaultMachineId) {
        String messageMachineId = exchange.getIn().getHeader(HEADER_MACHINE, String.class);
        if (messageMachineId == null) {
            LOG.debug("Machine ID specified in the header: {} ID will be used instead of default {}", messageMachineId, defaultMachineId);
            return messageMachineId;
        } else {
            LOG.debug("Machine ID not specified in header, using default machine ID: {}", defaultMachineId);
            return defaultMachineId;
        }
    }

}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy