Safe Haskell | None |
---|
- data TLSConfig
- tlsConfigBS :: HostPreference -> Int -> ByteString -> ByteString -> TLSConfig
- tlsConfig :: HostPreference -> Int -> FilePath -> FilePath -> TLSConfig
- tlsHost :: TLSConfig -> HostPreference
- tlsPort :: TLSConfig -> Int
- tlsNeedLocalAddr :: TLSConfig -> Bool
- tlsAppData :: Context -> SockAddr -> Maybe SockAddr -> AppData IO
- runTCPServerTLS :: TLSConfig -> Application IO -> IO ()
- runTCPServerStartTLS :: TLSConfig -> ApplicationStartTLS -> IO ()
- data TLSClientConfig m
- tlsClientConfig :: Int -> ByteString -> TLSClientConfig m
- runTLSClient :: (MonadIO m, MonadBaseControl IO m) => TLSClientConfig m -> Application m -> m ()
- runTLSClientStartTLS :: TLSClientConfig IO -> ApplicationStartTLS -> IO ()
- tlsClientPort :: TLSClientConfig m -> Int
- tlsClientHost :: TLSClientConfig m -> ByteString
- tlsClientUseTLS :: TLSClientConfig m -> Bool
- tlsClientTLSSettings :: TLSClientConfig m -> TLSSettings
- tlsClientSockSettings :: TLSClientConfig m -> Maybe SockSettings
- tlsClientConnectionContext :: TLSClientConfig m -> Maybe ConnectionContext
Server
:: HostPreference | |
-> Int | port |
-> ByteString | Certificate raw data |
-> ByteString | Key file raw data |
-> TLSConfig |
allow to build a server config directly from raw bytestring data (exact same string as if the certificates were read from the filesystem). this enables to plug another backend to fetch certifcates (other than FS)
Create an AppData
from an existing tls Context
value. This is a lower level function, allowing you to create a connection in any way you want.
Sample usage:
import Network.Simple.TCP.TLS myapp :: Application IO ... main = do cset <- getDefaultClientSettings connect cset "host" "port" $ (\(ctx, addr) -> myapp $ tlsAppData ctx addr Nothing)
Since 1.0.1
runTCPServerTLS :: TLSConfig -> Application IO -> IO ()Source
runTCPServerStartTLS :: TLSConfig -> ApplicationStartTLS -> IO ()Source
run a server un-crypted but also pass a call-back to trigger a StartTLS handshake on the underlying connection
example usage :
runTCPServerStartTLS serverConfig $ (appData,startTLS) -> do
abortTLS <- doSomethingInClear appData
unless (abortTLS) $ startTls $ appDataTls -> do
doSomethingSSL appDataTls
Client
data TLSClientConfig m Source
Settings type for TLS client connection.
Since 1.0.2
:: Int | port |
-> ByteString | host |
-> TLSClientConfig m |
Smart constructor for TLSClientConfig
.
Since 1.0.2
runTLSClient :: (MonadIO m, MonadBaseControl IO m) => TLSClientConfig m -> Application m -> m ()Source
Run an application with the given configuration.
Since 1.0.2
runTLSClientStartTLS :: TLSClientConfig IO -> ApplicationStartTLS -> IO ()Source
Run an application with the given configuration. starting with a clear connection but provide also a call back to trigger a StartTLS handshake on the connection
Since 1.0.2
tlsClientPort :: TLSClientConfig m -> IntSource
Since 1.0.2
tlsClientHost :: TLSClientConfig m -> ByteStringSource
Since 1.0.2
tlsClientUseTLS :: TLSClientConfig m -> BoolSource
Default is True. If set to False
, will make a non-TLS connection.
Since 1.0.2
tlsClientTLSSettings :: TLSClientConfig m -> TLSSettingsSource
TLS settings to use. If not provided, defaults will be provided.
Since 1.0.2
tlsClientSockSettings :: TLSClientConfig m -> Maybe SockSettingsSource
Socks configuration; default is Nothing
. If absent, Socks will not be used.
Since 1.0.2
tlsClientConnectionContext :: TLSClientConfig m -> Maybe ConnectionContextSource
Connection context. Default is Nothing
, which will generate a new
context automatically. If you will be making many connections, it's
recommended to call initConnectionContext
yourself.
Since 1.0.2