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

com.sshtools.server.components.SshKeyExchangeServer Maven / Gradle / Ivy

There is a newer version: 3.1.2
Show newest version
/**
 * (c) 2002-2021 JADAPTIVE Limited. All Rights Reserved.
 *
 * This file is part of the Maverick Synergy Java SSH API.
 *
 * Maverick Synergy 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.
 *
 * Maverick Synergy 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 Maverick Synergy.  If not, see .
 */

package com.sshtools.server.components;

import java.io.IOException;
import java.math.BigInteger;

import com.sshtools.common.ssh.SecurityLevel;
import com.sshtools.common.ssh.SshException;
import com.sshtools.common.ssh.components.SshPrivateKey;
import com.sshtools.common.ssh.components.SshPublicKey;
import com.sshtools.server.SshServerContext;
import com.sshtools.synergy.ssh.SshTransport;
import com.sshtools.synergy.ssh.components.SshKeyExchange;

/**
 * 
 * 

* Abstract representation of an SSH key exchange. *

* * */ public abstract class SshKeyExchangeServer implements SshKeyExchange { /** * The secret value produced during key exchange. */ protected BigInteger secret; /** * The exchange hash produced during key exchange. */ protected byte[] exchangeHash; /** * The server's host key. */ protected byte[] hostKey; /** * The signature generated over the exchange hash */ protected byte[] signature; protected String clientId; protected String serverId; protected byte[] clientKexInit; protected byte[] serverKexInit; protected SshPrivateKey prvkey; protected SshPublicKey pubkey; protected boolean firstPacketFollows; protected boolean useFirstPacket; boolean sentNewKeys = false; boolean receivedNewKeys = false; /** * The transport protocol for sending/receiving messages */ protected SshTransport transport; String hashAlgorithm; private final SecurityLevel securityLevel; final int priority; /** * Contruct an uninitialized key exchange */ public SshKeyExchangeServer(String hashAlgorithm, SecurityLevel securityLevel, int priority) { this.hashAlgorithm = hashAlgorithm; this.securityLevel = securityLevel; this.priority = priority; } public SecurityLevel getSecurityLevel() { return securityLevel; } public int getPriority() { return priority; } public void setReceivedNewKeys(boolean receivedNewKeys) { this.receivedNewKeys = receivedNewKeys; } public void setSentNewKeys(boolean sentNewKeys) { this.sentNewKeys = sentNewKeys; } public boolean hasSentNewKeys() { return sentNewKeys; } public boolean hasReceivedNewKeys() { return receivedNewKeys; } /* (non-Javadoc) * @see com.maverick.sshd.components.SshKeyExchangeServer#getHashAlgorithm() */ public String getHashAlgorithm() { return hashAlgorithm; } /** * Get the key exchange algorithm name. * * @return the key exchange algorithm. */ public abstract String getAlgorithm(); /* (non-Javadoc) * @see com.maverick.sshd.components.SshKeyExchangeServer#getExchangeHash() */ public byte[] getExchangeHash() { return exchangeHash; } /* (non-Javadoc) * @see com.maverick.sshd.components.SshKeyExchangeServer#getHostKey() */ public byte[] getHostKey() { return hostKey; } /* (non-Javadoc) * @see com.maverick.sshd.components.SshKeyExchangeServer#getSecret() */ public BigInteger getSecret() { return secret; } /* (non-Javadoc) * @see com.maverick.sshd.components.SshKeyExchangeServer#getSignature() */ public byte[] getSignature() { return signature; } /** * Process a key exchange message * * @param msg * @return boolean, indicating whether it has processed the message or not * @throws IOException */ public abstract boolean processMessage(byte[] msg) throws SshException, IOException; /** * Reset the key exchange. */ public void reset() { exchangeHash = null; hostKey = null; signature = null; secret = null; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy