module Examples.Raft.Socket.Common where
import Protolude
import qualified Data.ByteString as BS
import qualified Network.Simple.TCP as N
import qualified Network.Socket as NS
import qualified Data.Word8 as W8
import Raft.Types
hostPortToNid :: (N.HostName, N.ServiceName) -> NodeId
hostPortToNid (host, port) = toS $ host ++ ":" ++ toS port
nidToHostPort :: NodeId -> (N.HostName, N.ServiceName)
nidToHostPort bs =
case BS.split W8._colon bs of
[host,port] -> (toS host, toS port)
_ -> panic "nidToHostPort: invalid node id"
getFreePort :: IO N.ServiceName
getFreePort = do
sock <- NS.socket NS.AF_INET NS.Stream NS.defaultProtocol
NS.bind sock (NS.SockAddrInet NS.aNY_PORT NS.iNADDR_ANY)
port <- NS.socketPort sock
NS.close sock
pure $ show port