module Network.HTTP2.TLS.Client.Settings where

import Data.X509.CertificateStore (CertificateStore)
import Network.Socket

-- Client settings type.
data Settings = Settings
    { Settings -> String -> IO ()
settingsKeyLogger :: String -> IO ()
    -- ^ Key logger
    --
    -- Applications may wish to set this depending on the SSLKEYLOGFILE environment variable. Default is do nothing.
    , Settings -> Bool
settingsValidateCert :: Bool
    -- ^ Should we validate TLS certificates?
    --
    -- >>> settingsValidateCert defaultSettings
    -- True
    , Settings -> CertificateStore
settingsCAStore :: CertificateStore
    -- ^ Certificate store used for validation. The default is 'mempty'.
    , Settings -> [AddrInfoFlag]
settingsAddrInfoFlags :: [AddrInfoFlag]
    -- ^ Flags that control the querying behaviour of @getAddrInfo@.
    --
    -- >>> settingsAddrInfoFlags defaultSettings
    -- []
    }

-- | Default settings.
defaultSettings :: Settings
defaultSettings :: Settings
defaultSettings =
    Settings
        { settingsKeyLogger :: String -> IO ()
settingsKeyLogger = \String
_ -> forall (m :: * -> *) a. Monad m => a -> m a
return ()
        , settingsValidateCert :: Bool
settingsValidateCert = Bool
True
        , settingsCAStore :: CertificateStore
settingsCAStore = forall a. Monoid a => a
mempty
        , settingsAddrInfoFlags :: [AddrInfoFlag]
settingsAddrInfoFlags = []
        }