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

org.hidetake.groovy.ssh.operation.DefaultOperations.groovy Maven / Gradle / Ivy

There is a newer version: 2.11.2
Show newest version
package org.hidetake.groovy.ssh.operation

import groovy.util.logging.Slf4j
import org.hidetake.groovy.ssh.connection.Connection
import org.hidetake.groovy.ssh.core.Remote
import org.hidetake.groovy.ssh.session.forwarding.LocalPortForwardSettings
import org.hidetake.groovy.ssh.session.forwarding.RemotePortForwardSettings
import org.hidetake.groovy.ssh.session.transfer.FileTransferSettings

import static org.hidetake.groovy.ssh.util.Utility.callWithDelegate

/**
 * Default implementation of {@link Operations}.
 *
 * Operations should follow the logging convention, that is,
 * it should write a log as DEBUG on beginning of an operation,
 * it should write a log as INFO on success of an operation,
 * but it does not need to write a log if it is an internal operation.

 * @author Hidetake Iwata
 */
@Slf4j
class DefaultOperations implements Operations {
    final Remote remote

    private final Connection connection

    def DefaultOperations(Connection connection1) {
        connection = connection1
        remote = connection.remote
        assert connection
        assert remote
    }

    @Override
    Operation shell(ShellSettings settings) {
        log.debug("Executing shell on $remote.name: $settings")
        new Shell(connection, settings)
    }

    @Override
    Operation command(CommandSettings settings, String commandLine) {
        log.debug("Executing command on $remote.name: $commandLine: $settings")
        new Command(connection, settings, commandLine)
    }

    @Override
    int forwardLocalPort(LocalPortForwardSettings settings) {
        log.debug("Requesting port forwarding " +
                  "from $settings.bind:$settings.port " +
                  "to $remote.name [$settings.host:$settings.hostPort]")
        int port = connection.forwardLocalPort(settings)
        log.info("Enabled port forwarding " +
                 "from $settings.bind:$settings.port " +
                 "to $remote.name [$settings.host:$settings.hostPort]")
        port
    }

    @Override
    void forwardRemotePort(RemotePortForwardSettings settings) {
        log.debug("Requesting port forwarding " +
                  "from $remote.name [$settings.bind:$settings.port] " +
                  "to $settings.host:$settings.hostPort")
        connection.forwardRemotePort(settings)
        log.info("Enabled port forwarding from " +
                 "from $remote.name [$settings.bind:$settings.port] " +
                 "to $settings.host:$settings.hostPort")
    }

    @Override
    def  T sftp(FileTransferSettings settings, @DelegatesTo(SftpOperations) Closure closure) {
        log.debug("Requesting SFTP subsystem on $remote")
        def channel = connection.createSftpChannel()
        channel.connect(settings.timeoutSec * 1000)
        try {
            log.debug("Started SFTP $remote.name#$channel.id")
            def result = callWithDelegate(closure, new SftpOperations(remote, channel))
            log.debug("Finished SFTP $remote.name#$channel.id")
            result
        } finally {
            channel.disconnect()
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy