aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/ch/ethz/ssh2/packets/PacketKexDhGexGroup.java
blob: 4a4a69a55487dbaef9a83722167f82578febd4d9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
/*
 * Copyright (c) 2006-2011 Christian Plattner. All rights reserved.
 * Please refer to the LICENSE.txt for licensing details.
 */
package ch.ethz.ssh2.packets;

import java.io.IOException;

import java.math.BigInteger;

/**
 * PacketKexDhGexGroup.
 * 
 * @author Christian Plattner
 * @version 2.50, 03/15/10
 */
public class PacketKexDhGexGroup
{
	byte[] payload;

	BigInteger p;
	BigInteger g;

	public PacketKexDhGexGroup(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_GROUP)
			throw new IllegalArgumentException(
					"This is not a SSH_MSG_KEX_DH_GEX_GROUP! (" + packet_type
							+ ")");

		p = tr.readMPINT();
		g = tr.readMPINT();

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

	public BigInteger getG()
	{
		return g;
	}

	public BigInteger getP()
	{
		return p;
	}
}