view src/com/trilead/ssh2/packets/PacketKexDhGexReply.java @ 303:a218d9cd725b ganymed

add ecdsa key support everywhere
author Carl Byington <carl@five-ten-sg.com>
date Tue, 29 Jul 2014 20:24:24 -0700
parents 0ce5cc452d02
children
line wrap: on
line source


package com.trilead.ssh2.packets;

import java.io.IOException;

import java.math.BigInteger;

/**
 * PacketKexDhGexReply.
 *
 * @author Christian Plattner, plattner@trilead.com
 * @version $Id: PacketKexDhGexReply.java,v 1.1 2007/10/15 12:49:55 cplattne Exp $
 */
public class PacketKexDhGexReply {
    byte[] payload;

    byte[] hostKey;
    BigInteger f;
    byte[] signature;

    public PacketKexDhGexReply(byte payload[], int off, int len) throws IOException {
        this.payload = new byte[len];
        System.arraycopy(payload, off, this.payload, 0, len);
        TypesReader tr = new TypesReader(payload, off, len);
        int packet_type = tr.readByte();

        if (packet_type != Packets.SSH_MSG_KEX_DH_GEX_REPLY)
            throw new IOException("This is not a SSH_MSG_KEX_DH_GEX_REPLY! (" + packet_type + ")");

        hostKey = tr.readByteString();
        f = tr.readMPINT();
        signature = tr.readByteString();

        if (tr.remain() != 0)
            throw new IOException("PADDING IN SSH_MSG_KEX_DH_GEX_REPLY!");
    }

    public BigInteger getF() {
        return f;
    }

    public byte[] getHostKey() {
        return hostKey;
    }

    public byte[] getSignature() {
        return signature;
    }
}