Safe Haskell | Safe-Inferred |
---|---|
Language | Haskell2010 |
This module allows you to set per-connection keep alive parameters on windows, linux and darwin environments. For more information on keep alive signals see https://en.wikipedia.org/wiki/Keepalive. See also https://tldp.org/HOWTO/html_single/TCP-Keepalive-HOWTO/ for a linux specific implementation.
The module is meant to be used in conjuction with the "network" package. However, in order to ensure adaptability, all functions require a socket file descriptor instead of an implementation dependent socket type. For the network package, such a descriptor can be obtained with the withFdSocket function:
-- sock is a Socket type withFdSocket sock $ \fd -> do before <- getKeepAliveOnOff fd print before -- False -- set keep alive on, idle 60 seconds, interval 2 seconds rlt <- setKeepAlive fd $ KeepAlive True 60 2 case rlt of Left err -> print err Right () -> return () after <- getKeepAliveOnOff fd print after -- True
Please note that only the envocing process can manipulate sockets based on their file descriptors.
Synopsis
- data KeepAlive = KeepAlive {}
- data KeepAliveError
- setKeepAlive :: CInt -> KeepAlive -> IO (Either KeepAliveError ())
- getKeepAliveOnOff :: CInt -> IO Bool
Documentation
The main data structure defining keep alive parameters
data KeepAliveError Source #
Errors starting with WSA are windows specific
Instances
Eq KeepAliveError Source # | |
Defined in Network.Socket.KeepAlive (==) :: KeepAliveError -> KeepAliveError -> Bool # (/=) :: KeepAliveError -> KeepAliveError -> Bool # | |
Ord KeepAliveError Source # | |
Defined in Network.Socket.KeepAlive compare :: KeepAliveError -> KeepAliveError -> Ordering # (<) :: KeepAliveError -> KeepAliveError -> Bool # (<=) :: KeepAliveError -> KeepAliveError -> Bool # (>) :: KeepAliveError -> KeepAliveError -> Bool # (>=) :: KeepAliveError -> KeepAliveError -> Bool # max :: KeepAliveError -> KeepAliveError -> KeepAliveError # min :: KeepAliveError -> KeepAliveError -> KeepAliveError # | |
Show KeepAliveError Source # | |
Defined in Network.Socket.KeepAlive showsPrec :: Int -> KeepAliveError -> ShowS # show :: KeepAliveError -> String # showList :: [KeepAliveError] -> ShowS # |
:: CInt | Socket file descriptor |
-> KeepAlive | Keep alive parameters |
-> IO (Either KeepAliveError ()) |
Set keep alive parameters for the current socket