network-simple-tls-0.4.1: Simple interface to TLS secured network sockets.
Safe HaskellSafe-Inferred
LanguageHaskell2010

Network.Simple.TCP.TLS

Description

This module exports simple tools for establishing TLS-secured TCP connections, relevant to both the client side and server side of the connection.

This module re-exports some functions from the Network.Simple.TCP module in the network-simple package. Consider using that module directly if you need a similar API without TLS support.

This module uses MonadIO and MonadMask extensively so that you can reuse these functions in monads other than IO. However, if you don't care about any of that, just pretend you are using the IO monad all the time and everything will work as expected.

Synopsis

Server side

serve Source #

Arguments

:: MonadIO m 
=> ServerParams

TLS settings.

-> HostPreference

Preferred host to bind.

-> ServiceName

Service port to bind.

-> ((Context, SockAddr) -> IO ())

Computation to run in a different thread once an incomming connection is accepted and a TLS-secured communication is established. Takes the TLS connection context and remote end address.

-> m () 

Start a TLS-secured TCP server that accepts incoming connections and handles each of them concurrently, in different threads.

Any acquired network resources are properly closed and discarded when done or in case of exceptions. This function binds a listening socket, accepts an incoming connection, performs a TLS handshake and then safely closes the connection when done or in case of exceptions. You don't need to perform any of those steps manually.

Listening

listen #

Arguments

:: (MonadIO m, MonadMask m) 
=> HostPreference

Host to bind.

-> ServiceName

Server service port name or number to bind.

-> ((Socket, SockAddr) -> m r)

Computation taking the listening socket and the address it's bound to.

-> m r 

Bind a TCP listening socket and use it.

The listening socket is closed when done or in case of exceptions.

If you prefer to acquire and close the socket yourself, then use bindSock and closeSock, as well as listenSock function.

Note: The NoDelay, KeepAlive and ReuseAddr options are set on the socket. The maximum number of incoming queued connections is 2048.

Accepting

accept Source #

Arguments

:: (MonadIO m, MonadMask m) 
=> ServerParams

TLS settings.

-> Socket

Listening and bound socket.

-> ((Context, SockAddr) -> m r)

Computation to run in a different thread once an incomming connection is accepted and a TLS-secured communication is established. Takes the TLS connection context and remote end address.

-> m r 

Accepts a single incomming TLS-secured TCP connection and use it.

A TLS handshake is performed immediately after establishing the TCP connection and the TLS and TCP connections are properly closed when done or in case of exceptions. If you need to manage the lifetime of the connection resources yourself, then use acceptTls instead.

acceptFork Source #

Arguments

:: MonadIO m 
=> ServerParams

TLS settings.

-> Socket

Listening and bound socket.

-> ((Context, SockAddr) -> IO ())

Computation to run in a different thread once an incomming connection is accepted and a TLS-secured communication is established. Takes the TLS connection context and remote end address.

-> m ThreadId 

Like accept, except it uses a different thread to performs the TLS handshake and run the given computation.

Server TLS Settings

newDefaultServerParams Source #

Arguments

:: MonadIO m 
=> Credential

Server credential.

Can be loaded with credentialLoadX509 or similar functions.

-> m ServerParams 

Obtain new default ServerParams for a particular server Credential.

makeServerParams Source #

Arguments

:: Credential

Server credential.

Can be loaded with credentialLoadX509 or similar functions.

-> Maybe CertificateStore

CAs used to verify the client certificate.

If specified, then a valid client certificate will be expected during handshake.

Use getSystemCertificateStore to obtain the operating system's defaults.

-> ServerParams 

Make default ServerParams.

  • The supported cipher suites are those enumerated by ciphersuite_strong, in decreasing order of preference. The cipher suite preferred by the server is used.
  • Secure renegotiation initiated by the server is enabled, but renegotiation initiated by the client is disabled.
  • Only the TLS 1.1, TLS 1.2 and TLS 1.3 protocols are supported by default.

If you are unsatisfied with any of these settings, please please refer to the Network.TLS module for more documentation on ServerParams.

Client side

connect Source #

Arguments

:: (MonadIO m, MonadMask m) 
=> ClientParams

TLS settings.

-> HostName

Server hostname.

-> ServiceName

Destination server service port name or number.

-> ((Context, SockAddr) -> m r)

Computation to run after establishing TLS-secured TCP connection to the remote server. Takes the TLS connection context and remote end address.

-> m r 

Connect to a TLS-secured TCP server and use the connection

A TLS handshake is performed immediately after establishing the TCP connection and the TLS and TCP connections are properly closed when done or in case of exceptions. If you need to manage the lifetime of the connection resources yourself, then use connectTls instead.

connectOverSOCKS5 Source #

Arguments

:: (MonadIO m, MonadMask m) 
=> HostName

SOCKS5 proxy server hostname or IP address.

-> ServiceName

SOCKS5 proxy server service port name or number.

-> ClientParams

TLS settings.

-> HostName

Destination server hostname or IP address. We connect to this host through the SOCKS5 proxy specified in the previous arguments.

Note that if hostname resolution on this HostName is necessary, it will happen on the proxy side for security reasons, not locally.

-> ServiceName

Destination server service port name or number.

-> ((Context, SockAddr, SockAddr) -> m r)

Computation to run after establishing TLS-secured TCP connection to the remote server. Takes the TLS connection that can be used to interact with the destination server, as well as the address of the SOCKS5 server and the address of the destination server, in that order.

-> m r 

Like connect, but connects to the destination server over a SOCKS5 proxy.

Client TLS Settings

newDefaultClientParams Source #

Arguments

:: MonadIO m 
=> ServiceID
ServiceID ~ (HostName, ByteString)

Identification of the connection consisting of the fully qualified host name for the server (e.g. www.example.com) and an optional suffix.

It is important that the hostname part is properly filled for security reasons, as it allow to properly associate the remote side with the given certificate during a handshake.

The suffix is used to identity a certificate per service on a specific host. For example, a same host might have different certificates on differents ports (443 and 995). For TCP connections, it's recommended to use: :port, or :service for the blob (e.g., @":443", ":https"@).

-> m ClientParams 

Obtain new default ClientParams for a particular ServiceID.

  • No client credentials sumbitted to the server.
  • Use system-wide CA certificate store.
  • Use an in-memory TLS session manager from the tls-session-manager package.
  • Everything else as proposed by makeClientParams.

makeClientParams Source #

Arguments

:: ServiceID
ServiceID ~ (HostName, ByteString)

Identification of the connection consisting of the fully qualified host name for the server (e.g. www.example.com) and an optional suffix.

It is important that the hostname part is properly filled for security reasons, as it allow to properly associate the remote side with the given certificate during a handshake.

The suffix is used to identity a certificate per service on a specific host. For example, a same host might have different certificates on differents ports (443 and 995). For TCP connections, it's recommended to use: :port, or :service for the blob (e.g., @":443", ":https"@).

-> [Credential]

Credentials to provide to the server if requested. Only credentials matching the server's DistinguishedName will be submitted.

Can be loaded with credentialLoadX509 or similar functions.

-> CertificateStore

CAs used to verify the server certificate.

Use getSystemCertificateStore to obtain the operating system's defaults.

-> ClientParams 

Make defaults ClientParams.

  • Certificate chain validation is done by validateDefault from the Data.X509.Validation module.
  • The Server Name Indication (SNI) TLS extension is enabled.
  • The supported cipher suites are those enumerated by ciphersuite_default, in decreasing order of preference.
  • Secure renegotiation is enabled.
  • Only the TLS 1.1, TLS 1.2 and TLS 1.3 protocols are supported by default.

If you are unsatisfied with any of these settings, please please refer to the Network.TLS module for more documentation on ClientParams.

Utils

recv :: MonadIO m => Context -> m (Maybe ByteString) Source #

Receives decrypted bytes from the given Context. Returns Nothing on EOF.

Up to 16384 decrypted bytes will be received at once.

send :: MonadIO m => Context -> ByteString -> m () Source #

Encrypts the given strict ByteString and sends it through the Context.

sendLazy :: MonadIO m => Context -> ByteString -> m () Source #

Encrypts the given lazy ByteString and sends it through the Context.

Low level support

useTls :: (MonadIO m, MonadMask m) => ((Context, SockAddr) -> m a) -> (Context, SockAddr) -> m a Source #

Perform a TLS handshake on the given Context, then perform the given action and at last gracefully close the TLS session using bye.

This function does not close the underlying TCP connection when done. Prefer to use useTlsThenClose or useTlsThenCloseFork if you need that behavior. Otherwise, you must call contextClose yourself at some point.

useTlsThenClose :: (MonadIO m, MonadMask m) => ((Context, SockAddr) -> m a) -> (Context, SockAddr) -> m a Source #

Like useTls, except it also fully closes the TCP connection when done.

useTlsThenCloseFork :: MonadIO m => ((Context, SockAddr) -> IO ()) -> (Context, SockAddr) -> m ThreadId Source #

Similar to useTlsThenClose, except it performs the all the IO actions in a new thread.

Use this instead of forking useTlsThenClose yourself, as that won't give the right behavior.

connectTls Source #

Arguments

:: MonadIO m 
=> ClientParams

TLS settings.

-> HostName

Server hostname.

-> ServiceName

Server service name or port number.

-> m (Context, SockAddr) 

Estalbishes a TCP connection to a remote server and returns a TLS Context configured on top of it using the given ClientParams. The remote end address is also returned.

Prefer to use connect if you will be using the obtained Context within a limited scope.

You need to perform a TLS handshake on the resulting Context before using it for communication purposes, and gracefully close the TLS and TCP connections afterwards using. The useTls, useTlsThenClose and useTlsThenCloseFork can help you with that.

connectTlsOverSOCKS5 Source #

Arguments

:: MonadIO m 
=> HostName

SOCKS5 proxy server hostname or IP address.

-> ServiceName

SOCKS5 proxy server service port name or number.

-> ClientParams

TLS settings.

-> HostName

Destination server hostname or IP address. We connect to this host through the SOCKS5 proxy specified in the previous arguments.

Note that if hostname resolution on this HostName is necessary, it will happen on the proxy side for security reasons, not locally.

-> ServiceName

Destination server service port name or number.

-> m (Context, SockAddr, SockAddr)

Returns the Context that can be used to interact with the destination server, as well as the address of the SOCKS5 server and the address of the destination server, in that order.

Like connectTls, but connects to the destination server over a SOCKS5 proxy.

acceptTls Source #

Arguments

:: MonadIO m 
=> ServerParams

TLS settings.

-> Socket

Listening and bound socket.

-> m (Context, SockAddr) 

Accepts an incoming TCP connection and returns a TLS Context configured on top of it using the given ServerParams. The remote end address is also returned.

Prefer to use accept if you will be using the obtained Context within a limited scope.

You need to perform a TLS handshake on the resulting Context before using it for communication purposes, and gracefully close the TLS and TCP connections afterwards using. The useTls, useTlsThenClose and useTlsThenCloseFork can help you with that.

makeClientContext :: MonadIO m => ClientParams -> Socket -> m Context Source #

Make a client-side TLS Context for the given settings, on top of the given TCP Socket connected to the remote end.

makeServerContext :: MonadIO m => ServerParams -> Socket -> m Context Source #

Make a server-side TLS Context for the given settings, on top of the given TCP Socket connected to the remote end.

Re-exports

For your convenience, this module module also re-exports the following types from other modules:

From Network.Socket
HostName, ServiceName, Socket, SockAddr, withSocketsDo.
From Network.Simple.TCP
HostPreference(Host,HostAny,HostIPv4,HostIPv6).
From Network.TLS
Context, Credential, ServerParams, ClientParams, credentialLoadX509.

withSocketsDo :: IO a -> IO a #

With older versions of the network library (version 2.6.0.2 or earlier) on Windows operating systems, the networking subsystem must be initialised using withSocketsDo before any networking operations can be used. eg.

main = withSocketsDo $ do {...}

It is fine to nest calls to withSocketsDo, and to perform networking operations after withSocketsDo has returned.

withSocketsDo is not necessary for the current network library. However, for compatibility with older versions on Windows, it is good practice to always call withSocketsDo (it's very cheap).

data HostPreference #

Preferred host to bind.

Constructors

HostAny

Any available host.

HostIPv4

Any available IPv4 host.

HostIPv6

Any available IPv6 host.

Host HostName

An explicit host name.

type HostName = String #

Either a host name e.g., "haskell.org" or a numeric host address string consisting of a dotted decimal IPv4 address or an IPv6 address e.g., "192.168.0.1".

type ServiceName = String #

Either a service name e.g., "http" or a numeric port number.

A service port like "80" or its name "www".

data Socket #

Basic type for a socket.

Instances

Instances details
Show Socket 
Instance details

Defined in Network.Socket.Types

Eq Socket 
Instance details

Defined in Network.Socket.Types

Methods

(==) :: Socket -> Socket -> Bool #

(/=) :: Socket -> Socket -> Bool #

HasBackend Socket 
Instance details

Defined in Network.TLS.Backend

data SockAddr #

Socket addresses. The existence of a constructor does not necessarily imply that that socket address type is supported on your system: see isSupportedSockAddr.

Instances

Instances details
NFData SockAddr 
Instance details

Defined in Network.Socket.Types

Methods

rnf :: SockAddr -> () #

Eq SockAddr 
Instance details

Defined in Network.Socket.Types

Ord SockAddr 
Instance details

Defined in Network.Socket.Types

SocketAddress SockAddr 
Instance details

Defined in Network.Socket.Types

data Context #

A TLS Context keep tls specific state, parameters and backend information.

Please refer to the Network.TLS module for more documentation on ClientParams.

There's plenty to be changed, but the documentation for ClientParams is not rendered inside Network.Simple.TCP.TLS module.

Please refer to the Network.TLS module for more documentation on ServerParams.

There's plenty to be changed, but the documentation for ServerParams is not rendered inside Network.Simple.TCP.TLS module.

credentialLoadX509 Source #

Arguments

:: MonadIO m 
=> FilePath

Public certificate (X.509 format).

-> FilePath

Private key associated with the certificate.

-> m (Either String Credential) 

Try to create a new credential object from a public certificate and the associated private key that are stored on the filesystem in PEM format.