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

com.wl4g.components.common.cli.ssh2.SSH2Holders Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2017 ~ 2025 the original author or authors. 
 *
 * 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 com.wl4g.components.common.cli.ssh2;

import com.wl4g.components.common.collection.RegisteredUnmodifiableMap;
import com.wl4g.components.common.function.CallbackFunction;
import com.wl4g.components.common.function.ProcessFunction;
import com.wl4g.components.common.log.SmartLogger;

import java.io.CharArrayWriter;
import java.io.File;
import java.io.FileReader;
import java.io.IOException;
import java.util.HashMap;
import java.util.Map;

import static com.wl4g.components.common.lang.Assert2.isTrue;
import static com.wl4g.components.common.lang.Assert2.notNullOf;
import static com.wl4g.components.common.log.SmartLoggerFactory.getLogger;
import static org.apache.commons.lang3.StringUtils.join;
import static org.apache.commons.lang3.SystemUtils.USER_HOME;

/**
 * {@link SSH2Holders}, generic SSH2 client wrapper tool. 
* Including the implementation of ethz/ssj/ssd. * * @author Wangl.sir <[email protected], [email protected]> * @version 2020年1月9日 v1.0.0 * @see */ public abstract class SSH2Holders { final protected SmartLogger log = getLogger(getClass()); /** * Get default {@link SSH2Holders} instance by provider class. * * @param * @return */ @SuppressWarnings({ "rawtypes", "unchecked" }) public final static T getDefault() { return (T) getInstance(SshjHolder.class); } /** * Get {@link SSH2Holders} instance by provider class. * * @param * @param providerClass * @return */ @SuppressWarnings({ "unchecked", "rawtypes" }) public final static T getInstance(Class providerClass) { isTrue(providerRegistry.containsKey(providerClass), "No such ssh2 provider of : %s", providerClass); return (T) providerRegistry.get(providerClass); } // --- Transfer files. --- /** * Transfer get file from remote host.(user sftp) * * @param host * @param user * @param pemPrivateKey * @param localFile * @param remoteFilePath * @throws Exception */ public abstract void scpGetFile(String host, String user, char[] pemPrivateKey, String password, File localFile, String remoteFilePath) throws Exception; /** * Transfer put file to remote host directory. * * @param host * @param user * @param pemPrivateKey * @param localFile * @param remoteDir * @throws Exception */ public abstract void scpPutFile(String host, String user, char[] pemPrivateKey, String password, File localFile, String remoteDir) throws Exception; /** * Perform file transfer with remote host, including scp.put/upload or * scp.get/download. * * @param host * @param user * @param pemPrivateKey * @param processor * @throws IOException */ protected abstract void doScpTransfer(String host, String user, char[] pemPrivateKey, String password, CallbackFunction processor) throws Exception; // --- Execution commands. --- /** * Execution commands with SSH2. * * @param host * @param user * @param pemPrivateKey * @param command * @param timeoutMs * @return * @throws IOException */ public abstract SshExecResponse execWaitForResponse(String host, String user, char[] pemPrivateKey, String password, String command, long timeoutMs) throws Exception; /** * Execution commands wait for complete with SSH2 * * @param host * @param user * @param pemPrivateKey * @param command * @param processor * @param timeoutMs * @return * @throws IOException */ public abstract T execWaitForComplete(String host, String user, char[] pemPrivateKey, String password, String command, ProcessFunction processor, long timeoutMs) throws Exception; /** * Execution commands with SSH2 * * @param host * @param user * @param pemPrivateKey * @param command * @param processor * @return * @throws IOException */ public abstract T doExecCommand(String host, String user, char[] pemPrivateKey, String password, String command, ProcessFunction processor) throws Exception; /** * Get local current user ssh authentication private key of default. * * @param host * @param user * @return * @throws Exception */ protected final char[] getDefaultLocalUserPrivateKey() throws Exception { // Check private key. File privateKeyFile = new File(USER_HOME + "/.ssh/id_rsa"); isTrue(privateKeyFile.exists(), String.format("Not found privateKey for %s", privateKeyFile)); log.warn("Fallback use local user pemPrivateKey of: {}", privateKeyFile); try (CharArrayWriter cw = new CharArrayWriter(); FileReader fr = new FileReader(privateKeyFile.getAbsolutePath())) { char[] buff = new char[256]; int len = 0; while ((len = fr.read(buff)) != -1) { cw.write(buff, 0, len); } return cw.toCharArray(); } } // --- Tool function's. --- /** * Generate keypair of SSH2 based on RSA/DSA/ECDSA. * * @param type * Algorithm type(RSA/DSA/ECDSA). * @param comment * @return * @throws Exception */ public abstract Ssh2KeyPair generateKeypair(AlgorithmType type, String comment) throws Exception; /** * {@link SSH2Holders} provider registry. */ @SuppressWarnings("rawtypes") private final static Map, SSH2Holders> providerRegistry = new RegisteredUnmodifiableMap, SSH2Holders>( new HashMap<>()) { { putAll(new HashMap, SSH2Holders>() { private static final long serialVersionUID = 6854310693801773032L; { put(EthzHolder.class, new EthzHolder()); put(SshjHolder.class, new SshjHolder()); put(SshdHolder.class, new SshdHolder()); put(JschHolder.class, new JschHolder()); } }); } }; /** * Default IO buffer size. */ final public static int DEFAULT_TRANSFER_BUFFER = 1024 * 6; /** * {@link SshExecResponse} * * @author Wangl.sir <[email protected], [email protected]> * @version 2020年1月9日 v1.0.0 * @see */ public final static class SshExecResponse { /** Remote commands exit signal. */ final private String exitSignal; /** Remote commands exit code. */ final private Integer exitCode; /** Standard message */ final private String message; /** Error message */ final private String errmsg; public SshExecResponse(String exitSignal, Integer exitCode, String message, String errmsg) { super(); this.exitSignal = exitSignal; this.exitCode = exitCode; this.message = message; this.errmsg = errmsg; } public String getExitSignal() { return exitSignal; } public Integer getExitCode() { return exitCode; } public String getMessage() { return message; } public String getErrmsg() { return errmsg; } } /** * {@link Ssh2KeyPair} * * @author Wangl.sir <[email protected], [email protected]> * @version 2020年2月4日 v1.0.0 * @see */ public final static class Ssh2KeyPair { /** Generate ssh2 privateKey. */ final private String privateKey; /** Generate ssh2 publicKey. */ final private String publicKey; public Ssh2KeyPair(String privateKey, String publicKey) { notNullOf(privateKey, "privateKey"); notNullOf(publicKey, "publicKey"); this.privateKey = privateKey; this.publicKey = publicKey; } public String getPrivateKey() { return privateKey; } public String getPublicKey() { return publicKey; } } /** * {@link AlgorithmType} * * @author Wangl.sir <[email protected], [email protected]> * @version 2020年2月4日 v1.0.0 * @see */ public static enum AlgorithmType { RSA, DSA, ECDSA } /** * Default environments path for different Linux distributions.
* e.g: *

* CentOS: /etc/bashrc
* Ubuntu: /etc/bash.bashrc *

*/ @Deprecated final public static String DEFAULT_LINUX_ENV_CMD = join(new String[] { // e.g: CentOS|Ubuntu "source /etc/profile", // e.g: CentOS "source /etc/bashrc", // e.g: Ubuntu "source /etc/bash.bashrc", // e.g: CentOS|Ubuntu "source ~/.profile", // e.g: CentOS|Ubuntu "source ~/.bashrc" }, " "); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy