Package net.i2p.data.i2np
Class OutboundTunnelBuildReplyMessage
java.lang.Object
net.i2p.data.i2np.I2NPMessageImpl
net.i2p.data.i2np.TunnelBuildMessageBase
net.i2p.data.i2np.TunnelBuildReplyMessage
net.i2p.data.i2np.OutboundTunnelBuildReplyMessage
- All Implemented Interfaces:
I2NPMessage
public class OutboundTunnelBuildReplyMessage extends TunnelBuildReplyMessage
Sent from the OBEP to the tunnel creator via an inbound tunnel.
Contains one plaintext variable-sized reply record for the creator
and a variable number of encrypted records for the following hops.
This message must be garlic-encrypted to hide the contents from the OBGW.
Preliminary, see proposal 157.
- Since:
- 0.9.50
-
Nested Class Summary
Nested classes/interfaces inherited from class net.i2p.data.i2np.I2NPMessageImpl
I2NPMessageImpl.Builder
-
Field Summary
Fields Modifier and Type Field Description static int
MAX_PLAINTEXT_RECORD_SIZE
static int
MESSAGE_TYPE
static int
SHORT_RECORD_SIZE
Fields inherited from class net.i2p.data.i2np.TunnelBuildMessageBase
_records, MAX_RECORD_COUNT, RECORD_COUNT, RECORD_SIZE
Fields inherited from class net.i2p.data.i2np.I2NPMessageImpl
_context, _expiration, _log, CHECKSUM_LENGTH, DEFAULT_EXPIRATION_MS, HEADER_LENGTH
-
Constructor Summary
Constructors Constructor Description OutboundTunnelBuildReplyMessage(I2PAppContext context)
zero record count, will be set with readMessage()OutboundTunnelBuildReplyMessage(I2PAppContext context, int records)
-
Method Summary
Modifier and Type Method Description protected int
calculateWrittenLength()
calculate the message body's length (not including the header and footerProperties
getPlaintextOptions()
Get the data for the plaintext record.byte[]
getPlaintextRecord()
Get the data for the plaintext record.int
getPlaintextReply()
Get the data for the plaintext record.int
getPlaintextSlot()
Get the slot for the plaintext record.int
getType()
Return the unique identifier for this type of I2NP message, as defined in the I2NP specvoid
readMessage(byte[] data, int offset, int dataSize, int type)
Read the body into the data structures, after the initial type byte and the uniqueId / expiration, using the current class's format as defined by the I2NP specificationvoid
setPlaintextRecord(int slot, byte[] data)
Set the slot and data for the plaintext record.void
setPlaintextRecord(int slot, int reply)
Set the slot and data for the plaintext record.void
setPlaintextRecord(int slot, int reply, Properties props)
Set the slot and data for the plaintext record.void
setRecord(int index, EncryptedBuildRecord record)
String
toString()
protected int
writeMessageBody(byte[] out, int curIndex)
write the message body to the output array, starting at the given index.Methods inherited from class net.i2p.data.i2np.I2NPMessageImpl
createMessage, fromRawByteArray, fromRawByteArrayNTCP2, getMessageExpiration, getMessageSize, getRawMessageSize, getUniqueId, readBytes, readBytes, readBytes, readMessage, registerBuilder, setMessageExpiration, setUniqueId, toByteArray, toByteArray, toByteArray, toRawByteArray, toRawByteArrayNTCP2, writeBytes
-
Field Details
-
MESSAGE_TYPE
public static final int MESSAGE_TYPE- See Also:
- Constant Field Values
-
SHORT_RECORD_SIZE
public static final int SHORT_RECORD_SIZE- See Also:
- Constant Field Values
-
MAX_PLAINTEXT_RECORD_SIZE
public static final int MAX_PLAINTEXT_RECORD_SIZE- See Also:
- Constant Field Values
-
-
Constructor Details
-
OutboundTunnelBuildReplyMessage
zero record count, will be set with readMessage() -
OutboundTunnelBuildReplyMessage
-
-
Method Details
-
setRecord
- Overrides:
setRecord
in classTunnelBuildMessageBase
- Parameters:
record
- must be ShortEncryptedBuildRecord or null- Throws:
IllegalArgumentException
- on bad slot or record length.
-
setPlaintextRecord
public void setPlaintextRecord(int slot, int reply)Set the slot and data for the plaintext record. Empty properties will be used.- Parameters:
reply
- 0-255- Throws:
IllegalArgumentException
- on bad slot or data length.- Since:
- 0.9.51
-
setPlaintextRecord
Set the slot and data for the plaintext record.- Parameters:
reply
- 0-255props
- may be null- Throws:
IllegalArgumentException
- on bad slot or data length.DataFormatException
- Since:
- 0.9.51
-
setPlaintextRecord
public void setPlaintextRecord(int slot, byte[] data)Set the slot and data for the plaintext record.- Throws:
IllegalArgumentException
- on bad slot or data length.
-
getPlaintextSlot
public int getPlaintextSlot()Get the slot for the plaintext record. getRecord() for this slot will return null. -
getPlaintextRecord
public byte[] getPlaintextRecord()Get the data for the plaintext record. -
getPlaintextReply
public int getPlaintextReply()Get the data for the plaintext record.- Since:
- 0.9.51
-
getPlaintextOptions
Get the data for the plaintext record.- Throws:
DataFormatException
- Since:
- 0.9.51
-
calculateWrittenLength
protected int calculateWrittenLength()Description copied from class:I2NPMessageImpl
calculate the message body's length (not including the header and footer- Overrides:
calculateWrittenLength
in classTunnelBuildMessageBase
-
getType
public int getType()Description copied from interface:I2NPMessage
Return the unique identifier for this type of I2NP message, as defined in the I2NP spec- Specified by:
getType
in interfaceI2NPMessage
- Overrides:
getType
in classTunnelBuildReplyMessage
-
readMessage
public void readMessage(byte[] data, int offset, int dataSize, int type) throws I2NPMessageExceptionDescription copied from interface:I2NPMessage
Read the body into the data structures, after the initial type byte and the uniqueId / expiration, using the current class's format as defined by the I2NP specification- Specified by:
readMessage
in interfaceI2NPMessage
- Overrides:
readMessage
in classTunnelBuildMessageBase
- Parameters:
data
- data to read fromoffset
- where to start in the data arraydataSize
- how long into the data to readtype
- I2NP message type- Throws:
I2NPMessageException
- if the stream doesn't contain a valid message that this class can read.
-
writeMessageBody
Description copied from class:I2NPMessageImpl
write the message body to the output array, starting at the given index.- Overrides:
writeMessageBody
in classTunnelBuildMessageBase
- Returns:
- the index into the array after the last byte written (NOT the length)
- Throws:
I2NPMessageException
-
toString
- Overrides:
toString
in classTunnelBuildReplyMessage
-