Package org.bouncycastle.crypto.tls
Class TlsProtocol
- java.lang.Object
-
- org.bouncycastle.crypto.tls.TlsProtocol
-
- Direct Known Subclasses:
TlsClientProtocol,TlsServerProtocol
public abstract class TlsProtocol extends java.lang.Object
-
-
Field Summary
Fields Modifier and Type Field Description protected static shortADS_MODE_0_Nprotected static shortADS_MODE_0_N_FIRSTONLYprotected static shortADS_MODE_1_Nsub1protected booleanallowCertificateStatusprotected booleanblockingprotected java.util.HashtableclientExtensionsprotected shortconnection_stateprotected static shortCS_CERTIFICATE_REQUESTprotected static shortCS_CERTIFICATE_STATUSprotected static shortCS_CERTIFICATE_VERIFYprotected static shortCS_CLIENT_CERTIFICATEprotected static shortCS_CLIENT_FINISHEDprotected static shortCS_CLIENT_HELLOprotected static shortCS_CLIENT_KEY_EXCHANGEprotected static shortCS_CLIENT_SUPPLEMENTAL_DATAprotected static shortCS_ENDprotected static shortCS_SERVER_CERTIFICATEprotected static shortCS_SERVER_FINISHEDprotected static shortCS_SERVER_HELLOprotected static shortCS_SERVER_HELLO_DONEprotected static shortCS_SERVER_KEY_EXCHANGEprotected static shortCS_SERVER_SESSION_TICKETprotected static shortCS_SERVER_SUPPLEMENTAL_DATAprotected static shortCS_STARTprotected booleanexpectSessionTicketprotected static java.lang.IntegerEXT_RenegotiationInfoprotected static java.lang.IntegerEXT_SessionTicketprotected ByteQueueInputStreaminputBuffersprotected int[]offeredCipherSuitesprotected short[]offeredCompressionMethodsprotected ByteQueueOutputStreamoutputBufferprotected CertificatepeerCertificateprotected booleanreceivedChangeCipherSpecprotected booleanresumedSessionprotected booleansecure_renegotiationprotected java.security.SecureRandomsecureRandomprotected SecurityParameterssecurityParametersprotected java.util.HashtableserverExtensionsprotected SessionParameterssessionParametersprotected TlsSessiontlsSession
-
Constructor Summary
Constructors Constructor Description TlsProtocol(java.io.InputStream input, java.io.OutputStream output, java.security.SecureRandom secureRandom)TlsProtocol(java.security.SecureRandom secureRandom)
-
Method Summary
All Methods Static Methods Instance Methods Abstract Methods Concrete Methods Modifier and Type Method Description protected intapplicationDataAvailable()protected voidapplyMaxFragmentLengthExtension()protected static voidassertEmpty(java.io.ByteArrayInputStream buf)Make sure the InputStream 'buf' now empty.protected voidblockForHandshake()protected voidcheckReceivedChangeCipherSpec(boolean expected)protected voidcleanupHandshake()voidclose()Closes this connection.voidcloseInput()Should be called in non-blocking mode when the input data reaches EOF.protected voidcompleteHandshake()protected static byte[]createRandomBlock(boolean useGMTUnixTime, RandomGenerator randomGenerator)protected static byte[]createRenegotiationInfo(byte[] renegotiated_connection)protected byte[]createVerifyData(boolean isServer)protected static voidestablishMasterSecret(TlsContext context, TlsKeyExchange keyExchange)protected voidflush()intgetAvailableInputBytes()Gets the amount of received application data.intgetAvailableOutputBytes()Gets the amount of encrypted data available to be sent.protected abstract TlsContextgetContext()protected static byte[]getCurrentPRFHash(TlsContext context, TlsHandshakeHash handshakeHash, byte[] sslSender)'sender' only relevant to SSLv3java.io.InputStreamgetInputStream()java.io.OutputStreamgetOutputStream()protected abstract TlsPeergetPeer()protected static intgetPRFAlgorithm(TlsContext context, int ciphersuite)protected voidhandleAlertMessage(short alertLevel, short alertDescription)protected voidhandleAlertWarningMessage(short alertDescription)protected voidhandleChangeCipherSpecMessage()protected voidhandleClose(boolean user_canceled)protected voidhandleException(short alertDescription, java.lang.String message, java.lang.Throwable cause)protected voidhandleFailure()protected abstract voidhandleHandshakeMessage(short type, java.io.ByteArrayInputStream buf)protected voidinvalidateSession()booleanisClosed()voidofferInput(byte[] input)Offer input from an arbitrary source.voidofferOutput(byte[] buffer, int offset, int length)Offer output from an arbitrary source.protected voidprocessFinishedMessage(java.io.ByteArrayInputStream buf)protected shortprocessMaxFragmentLengthExtension(java.util.Hashtable clientExtensions, java.util.Hashtable serverExtensions, short alertDescription)protected voidprocessRecord(short protocol, byte[] buf, int off, int len)protected voidraiseAlertFatal(short alertDescription, java.lang.String message, java.lang.Throwable cause)protected voidraiseAlertWarning(short alertDescription, java.lang.String message)protected intreadApplicationData(byte[] buf, int offset, int len)Read data from the network.protected static java.util.HashtablereadExtensions(java.io.ByteArrayInputStream input)intreadInput(byte[] buffer, int offset, int length)Retrieves received application data.intreadOutput(byte[] buffer, int offset, int length)Retrieves encrypted data to be sent.protected static java.util.VectorreadSupplementalDataMessage(java.io.ByteArrayInputStream input)protected voidrefuseRenegotiation()protected voidsafeCheckRecordHeader(byte[] recordHeader)protected voidsafeReadRecord()protected voidsafeWriteRecord(short type, byte[] buf, int offset, int len)protected voidsendCertificateMessage(Certificate certificate)protected voidsendChangeCipherSpecMessage()protected voidsendFinishedMessage()protected voidsendSupplementalDataMessage(java.util.Vector supplementalData)protected voidsetAppDataSplitMode(int appDataSplitMode)protected voidwriteData(byte[] buf, int offset, int len)Send some application data to the remote system.protected static voidwriteExtensions(java.io.OutputStream output, java.util.Hashtable extensions)protected voidwriteHandshakeMessage(byte[] buf, int off, int len)protected static voidwriteSelectedExtensions(java.io.OutputStream output, java.util.Hashtable extensions, boolean selectEmpty)protected static voidwriteSupplementalData(java.io.OutputStream output, java.util.Vector supplementalData)
-
-
-
Field Detail
-
EXT_RenegotiationInfo
protected static final java.lang.Integer EXT_RenegotiationInfo
-
EXT_SessionTicket
protected static final java.lang.Integer EXT_SessionTicket
-
CS_START
protected static final short CS_START
- See Also:
- Constant Field Values
-
CS_CLIENT_HELLO
protected static final short CS_CLIENT_HELLO
- See Also:
- Constant Field Values
-
CS_SERVER_HELLO
protected static final short CS_SERVER_HELLO
- See Also:
- Constant Field Values
-
CS_SERVER_SUPPLEMENTAL_DATA
protected static final short CS_SERVER_SUPPLEMENTAL_DATA
- See Also:
- Constant Field Values
-
CS_SERVER_CERTIFICATE
protected static final short CS_SERVER_CERTIFICATE
- See Also:
- Constant Field Values
-
CS_CERTIFICATE_STATUS
protected static final short CS_CERTIFICATE_STATUS
- See Also:
- Constant Field Values
-
CS_SERVER_KEY_EXCHANGE
protected static final short CS_SERVER_KEY_EXCHANGE
- See Also:
- Constant Field Values
-
CS_CERTIFICATE_REQUEST
protected static final short CS_CERTIFICATE_REQUEST
- See Also:
- Constant Field Values
-
CS_SERVER_HELLO_DONE
protected static final short CS_SERVER_HELLO_DONE
- See Also:
- Constant Field Values
-
CS_CLIENT_SUPPLEMENTAL_DATA
protected static final short CS_CLIENT_SUPPLEMENTAL_DATA
- See Also:
- Constant Field Values
-
CS_CLIENT_CERTIFICATE
protected static final short CS_CLIENT_CERTIFICATE
- See Also:
- Constant Field Values
-
CS_CLIENT_KEY_EXCHANGE
protected static final short CS_CLIENT_KEY_EXCHANGE
- See Also:
- Constant Field Values
-
CS_CERTIFICATE_VERIFY
protected static final short CS_CERTIFICATE_VERIFY
- See Also:
- Constant Field Values
-
CS_CLIENT_FINISHED
protected static final short CS_CLIENT_FINISHED
- See Also:
- Constant Field Values
-
CS_SERVER_SESSION_TICKET
protected static final short CS_SERVER_SESSION_TICKET
- See Also:
- Constant Field Values
-
CS_SERVER_FINISHED
protected static final short CS_SERVER_FINISHED
- See Also:
- Constant Field Values
-
CS_END
protected static final short CS_END
- See Also:
- Constant Field Values
-
ADS_MODE_1_Nsub1
protected static final short ADS_MODE_1_Nsub1
- See Also:
- Constant Field Values
-
ADS_MODE_0_N
protected static final short ADS_MODE_0_N
- See Also:
- Constant Field Values
-
ADS_MODE_0_N_FIRSTONLY
protected static final short ADS_MODE_0_N_FIRSTONLY
- See Also:
- Constant Field Values
-
secureRandom
protected java.security.SecureRandom secureRandom
-
tlsSession
protected TlsSession tlsSession
-
sessionParameters
protected SessionParameters sessionParameters
-
securityParameters
protected SecurityParameters securityParameters
-
peerCertificate
protected Certificate peerCertificate
-
offeredCipherSuites
protected int[] offeredCipherSuites
-
offeredCompressionMethods
protected short[] offeredCompressionMethods
-
clientExtensions
protected java.util.Hashtable clientExtensions
-
serverExtensions
protected java.util.Hashtable serverExtensions
-
connection_state
protected short connection_state
-
resumedSession
protected boolean resumedSession
-
receivedChangeCipherSpec
protected boolean receivedChangeCipherSpec
-
secure_renegotiation
protected boolean secure_renegotiation
-
allowCertificateStatus
protected boolean allowCertificateStatus
-
expectSessionTicket
protected boolean expectSessionTicket
-
blocking
protected boolean blocking
-
inputBuffers
protected ByteQueueInputStream inputBuffers
-
outputBuffer
protected ByteQueueOutputStream outputBuffer
-
-
Method Detail
-
getContext
protected abstract TlsContext getContext()
-
getPeer
protected abstract TlsPeer getPeer()
-
handleAlertMessage
protected void handleAlertMessage(short alertLevel, short alertDescription) throws java.io.IOException- Throws:
java.io.IOException
-
handleAlertWarningMessage
protected void handleAlertWarningMessage(short alertDescription) throws java.io.IOException- Throws:
java.io.IOException
-
handleChangeCipherSpecMessage
protected void handleChangeCipherSpecMessage() throws java.io.IOException- Throws:
java.io.IOException
-
handleClose
protected void handleClose(boolean user_canceled) throws java.io.IOException- Throws:
java.io.IOException
-
handleException
protected void handleException(short alertDescription, java.lang.String message, java.lang.Throwable cause) throws java.io.IOException- Throws:
java.io.IOException
-
handleFailure
protected void handleFailure()
-
handleHandshakeMessage
protected abstract void handleHandshakeMessage(short type, java.io.ByteArrayInputStream buf) throws java.io.IOException- Throws:
java.io.IOException
-
applyMaxFragmentLengthExtension
protected void applyMaxFragmentLengthExtension() throws java.io.IOException- Throws:
java.io.IOException
-
checkReceivedChangeCipherSpec
protected void checkReceivedChangeCipherSpec(boolean expected) throws java.io.IOException- Throws:
java.io.IOException
-
cleanupHandshake
protected void cleanupHandshake()
-
blockForHandshake
protected void blockForHandshake() throws java.io.IOException- Throws:
java.io.IOException
-
completeHandshake
protected void completeHandshake() throws java.io.IOException- Throws:
java.io.IOException
-
processRecord
protected void processRecord(short protocol, byte[] buf, int off, int len) throws java.io.IOException- Throws:
java.io.IOException
-
applicationDataAvailable
protected int applicationDataAvailable()
-
readApplicationData
protected int readApplicationData(byte[] buf, int offset, int len) throws java.io.IOExceptionRead data from the network. The method will return immediately, if there is still some data left in the buffer, or block until some application data has been read from the network.- Parameters:
buf- The buffer where the data will be copied to.offset- The position where the data will be placed in the buffer.len- The maximum number of bytes to read.- Returns:
- The number of bytes read.
- Throws:
java.io.IOException- If something goes wrong during reading data.
-
safeCheckRecordHeader
protected void safeCheckRecordHeader(byte[] recordHeader) throws java.io.IOException- Throws:
java.io.IOException
-
safeReadRecord
protected void safeReadRecord() throws java.io.IOException- Throws:
java.io.IOException
-
safeWriteRecord
protected void safeWriteRecord(short type, byte[] buf, int offset, int len) throws java.io.IOException- Throws:
java.io.IOException
-
writeData
protected void writeData(byte[] buf, int offset, int len) throws java.io.IOExceptionSend some application data to the remote system.The method will handle fragmentation internally.
- Parameters:
buf- The buffer with the data.offset- The position in the buffer where the data is placed.len- The length of the data.- Throws:
java.io.IOException- If something goes wrong during sending.
-
setAppDataSplitMode
protected void setAppDataSplitMode(int appDataSplitMode)
-
writeHandshakeMessage
protected void writeHandshakeMessage(byte[] buf, int off, int len) throws java.io.IOException- Throws:
java.io.IOException
-
getOutputStream
public java.io.OutputStream getOutputStream()
- Returns:
- An OutputStream which can be used to send data. Only allowed in blocking mode.
-
getInputStream
public java.io.InputStream getInputStream()
- Returns:
- An InputStream which can be used to read data. Only allowed in blocking mode.
-
closeInput
public void closeInput() throws java.io.IOExceptionShould be called in non-blocking mode when the input data reaches EOF.- Throws:
java.io.IOException
-
offerInput
public void offerInput(byte[] input) throws java.io.IOExceptionOffer input from an arbitrary source. Only allowed in non-blocking mode.
After this method returns, the input buffer is "owned" by this object. Other code must not attempt to do anything with it.
This method will decrypt and process all records that are fully available. If only part of a record is available, the buffer will be retained until the remainder of the record is offered.
If any records containing application data were processed, the decrypted data can be obtained usingreadInput(byte[], int, int). If any records containing protocol data were processed, a response may have been generated. You should always check to see if there is any available output after calling this method by callinggetAvailableOutputBytes().- Parameters:
input- The input buffer to offer- Throws:
java.io.IOException- If an error occurs while decrypting or processing a record
-
getAvailableInputBytes
public int getAvailableInputBytes()
Gets the amount of received application data. A call toreadInput(byte[], int, int)is guaranteed to be able to return at least this much data.
Only allowed in non-blocking mode.- Returns:
- The number of bytes of available application data
-
readInput
public int readInput(byte[] buffer, int offset, int length)Retrieves received application data. UsegetAvailableInputBytes()to check how much application data is currently available. This method functions similarly toInputStream.read(byte[], int, int), except that it never blocks. If no data is available, nothing will be copied and zero will be returned.
Only allowed in non-blocking mode.- Parameters:
buffer- The buffer to hold the application dataoffset- The start offset in the buffer at which the data is writtenlength- The maximum number of bytes to read- Returns:
- The total number of bytes copied to the buffer. May be less than the length specified if the length was greater than the amount of available data.
-
offerOutput
public void offerOutput(byte[] buffer, int offset, int length) throws java.io.IOExceptionOffer output from an arbitrary source. Only allowed in non-blocking mode.
After this method returns, the specified section of the buffer will have been processed. UsereadOutput(byte[], int, int)to get the bytes to transmit to the other peer.
This method must not be called until after the handshake is complete! Attempting to call it before the handshake is complete will result in an exception.- Parameters:
buffer- The buffer containing application data to encryptoffset- The offset at which to begin reading datalength- The number of bytes of data to read- Throws:
java.io.IOException- If an error occurs encrypting the data, or the handshake is not complete
-
getAvailableOutputBytes
public int getAvailableOutputBytes()
Gets the amount of encrypted data available to be sent. A call toreadOutput(byte[], int, int)is guaranteed to be able to return at least this much data.
Only allowed in non-blocking mode.- Returns:
- The number of bytes of available encrypted data
-
readOutput
public int readOutput(byte[] buffer, int offset, int length)Retrieves encrypted data to be sent. UsegetAvailableOutputBytes()to check how much encrypted data is currently available. This method functions similarly toInputStream.read(byte[], int, int), except that it never blocks. If no data is available, nothing will be copied and zero will be returned.
Only allowed in non-blocking mode.- Parameters:
buffer- The buffer to hold the encrypted dataoffset- The start offset in the buffer at which the data is writtenlength- The maximum number of bytes to read- Returns:
- The total number of bytes copied to the buffer. May be less than the length specified if the length was greater than the amount of available data.
-
invalidateSession
protected void invalidateSession()
-
processFinishedMessage
protected void processFinishedMessage(java.io.ByteArrayInputStream buf) throws java.io.IOException- Throws:
java.io.IOException
-
raiseAlertFatal
protected void raiseAlertFatal(short alertDescription, java.lang.String message, java.lang.Throwable cause) throws java.io.IOException- Throws:
java.io.IOException
-
raiseAlertWarning
protected void raiseAlertWarning(short alertDescription, java.lang.String message) throws java.io.IOException- Throws:
java.io.IOException
-
sendCertificateMessage
protected void sendCertificateMessage(Certificate certificate) throws java.io.IOException
- Throws:
java.io.IOException
-
sendChangeCipherSpecMessage
protected void sendChangeCipherSpecMessage() throws java.io.IOException- Throws:
java.io.IOException
-
sendFinishedMessage
protected void sendFinishedMessage() throws java.io.IOException- Throws:
java.io.IOException
-
sendSupplementalDataMessage
protected void sendSupplementalDataMessage(java.util.Vector supplementalData) throws java.io.IOException- Throws:
java.io.IOException
-
createVerifyData
protected byte[] createVerifyData(boolean isServer)
-
close
public void close() throws java.io.IOExceptionCloses this connection.- Throws:
java.io.IOException- If something goes wrong during closing.
-
flush
protected void flush() throws java.io.IOException- Throws:
java.io.IOException
-
isClosed
public boolean isClosed()
-
processMaxFragmentLengthExtension
protected short processMaxFragmentLengthExtension(java.util.Hashtable clientExtensions, java.util.Hashtable serverExtensions, short alertDescription) throws java.io.IOException- Throws:
java.io.IOException
-
refuseRenegotiation
protected void refuseRenegotiation() throws java.io.IOException- Throws:
java.io.IOException
-
assertEmpty
protected static void assertEmpty(java.io.ByteArrayInputStream buf) throws java.io.IOExceptionMake sure the InputStream 'buf' now empty. Fail otherwise.- Parameters:
buf- The InputStream to check.- Throws:
java.io.IOException- If 'buf' is not empty.
-
createRandomBlock
protected static byte[] createRandomBlock(boolean useGMTUnixTime, RandomGenerator randomGenerator)
-
createRenegotiationInfo
protected static byte[] createRenegotiationInfo(byte[] renegotiated_connection) throws java.io.IOException- Throws:
java.io.IOException
-
establishMasterSecret
protected static void establishMasterSecret(TlsContext context, TlsKeyExchange keyExchange) throws java.io.IOException
- Throws:
java.io.IOException
-
getCurrentPRFHash
protected static byte[] getCurrentPRFHash(TlsContext context, TlsHandshakeHash handshakeHash, byte[] sslSender)
'sender' only relevant to SSLv3
-
readExtensions
protected static java.util.Hashtable readExtensions(java.io.ByteArrayInputStream input) throws java.io.IOException- Throws:
java.io.IOException
-
readSupplementalDataMessage
protected static java.util.Vector readSupplementalDataMessage(java.io.ByteArrayInputStream input) throws java.io.IOException- Throws:
java.io.IOException
-
writeExtensions
protected static void writeExtensions(java.io.OutputStream output, java.util.Hashtable extensions) throws java.io.IOException- Throws:
java.io.IOException
-
writeSelectedExtensions
protected static void writeSelectedExtensions(java.io.OutputStream output, java.util.Hashtable extensions, boolean selectEmpty) throws java.io.IOException- Throws:
java.io.IOException
-
writeSupplementalData
protected static void writeSupplementalData(java.io.OutputStream output, java.util.Vector supplementalData) throws java.io.IOException- Throws:
java.io.IOException
-
getPRFAlgorithm
protected static int getPRFAlgorithm(TlsContext context, int ciphersuite) throws java.io.IOException
- Throws:
java.io.IOException
-
-