module Network.TLS.Handshake.Control (
ClientState(..)
, ServerState(..)
, EarlySecretInfo(..)
, HandshakeSecretInfo(..)
, ApplicationSecretInfo(..)
, NegotiatedProtocol
) where
import Network.TLS.Cipher
import Network.TLS.Imports
import Network.TLS.Struct
import Network.TLS.Types
type NegotiatedProtocol = ByteString
data EarlySecretInfo = EarlySecretInfo Cipher (ClientTrafficSecret EarlySecret)
deriving Show
data HandshakeSecretInfo = HandshakeSecretInfo Cipher (TrafficSecrets HandshakeSecret)
deriving Show
newtype ApplicationSecretInfo = ApplicationSecretInfo (TrafficSecrets ApplicationSecret)
deriving Show
data ClientState =
SendClientHello (Maybe EarlySecretInfo)
| RecvServerHello HandshakeSecretInfo
| SendClientFinished [ExtensionRaw] ApplicationSecretInfo
data ServerState =
SendServerHello [ExtensionRaw] (Maybe EarlySecretInfo) HandshakeSecretInfo
| SendServerFinished ApplicationSecretInfo