Safe Haskell | None |
---|---|
Language | Haskell2010 |
This module provides types and functions for combining partial
configs into a complete configs to ultimately make a Plan
.
This module has two classes of types.
Types like PartialProcessConfig
that could be used by any
library that needs to combine process options.
Finally it has types and functions for creating Plan
s that
use temporary resources. This is used to create the default
behavior of startConfig
and related
functions.
|
Synopsis
- data PartialEnvVars = PartialEnvVars {}
- completePartialEnvVars :: [(String, String)] -> PartialEnvVars -> Either [String] [(String, String)]
- data PartialCommandLineArgs = PartialCommandLineArgs {}
- completeCommandLineArgs :: PartialCommandLineArgs -> [String]
- data PartialProcessConfig = PartialProcessConfig {}
- standardProcessConfig :: PartialProcessConfig
- completeProcessConfig :: [(String, String)] -> PartialProcessConfig -> Either [String] ProcessConfig
- data DirectoryType
- toFilePath :: DirectoryType -> FilePath
- data PartialDirectoryType
- setupDirectoryType :: String -> PartialDirectoryType -> IO DirectoryType
- cleanupDirectoryType :: DirectoryType -> IO ()
- data SocketClass
- socketClassToConfig :: SocketClass -> [String]
- socketClassToHostFlag :: SocketClass -> [(String, Maybe String)]
- socketClassToHost :: SocketClass -> String
- data PartialSocketClass
- setupPartialSocketClass :: PartialSocketClass -> IO SocketClass
- cleanupSocketConfig :: SocketClass -> IO ()
- data PartialPostgresPlan = PartialPostgresPlan {}
- completePostgresPlan :: [(String, String)] -> PartialPostgresPlan -> Either [String] PostgresPlan
- data PartialPlan = PartialPlan {}
- completePlan :: [(String, String)] -> PartialPlan -> Either [String] Plan
- data Resources = Resources {}
- makeResourcesDataDirPermanent :: Resources -> Resources
- data Config = Config {}
- toPlan :: Bool -> Bool -> Int -> SocketClass -> FilePath -> PartialPlan
- setupConfig :: Config -> IO Resources
- cleanupConfig :: Resources -> IO ()
- optionsToConfig :: Options -> Config
- type Lens s t a b = forall f. Functor f => (a -> f b) -> s -> f t
- type Lens' s a = Lens s s a a
- partialEnvVarsInheritL :: Lens' PartialEnvVars (Last Bool)
- partialEnvVarsSpecificL :: Lens' PartialEnvVars (Map String String)
- partialProcessConfigCmdLineL :: Lens' PartialProcessConfig PartialCommandLineArgs
- partialProcessConfigEnvVarsL :: Lens' PartialProcessConfig PartialEnvVars
- partialProcessConfigStdErrL :: Lens' PartialProcessConfig (Last Handle)
- partialProcessConfigStdInL :: Lens' PartialProcessConfig (Last Handle)
- partialProcessConfigStdOutL :: Lens' PartialProcessConfig (Last Handle)
- partialPostgresPlanClientConfigL :: Lens' PartialPostgresPlan Options
- partialPostgresPlanProcessConfigL :: Lens' PartialPostgresPlan PartialProcessConfig
- partialPlanConfigL :: Lens' PartialPlan [String]
- partialPlanCreateDbL :: Lens' PartialPlan (Maybe PartialProcessConfig)
- partialPlanDataDirectoryL :: Lens' PartialPlan (Last String)
- partialPlanInitDbL :: Lens' PartialPlan (Maybe PartialProcessConfig)
- partialPlanLoggerL :: Lens' PartialPlan (Last Logger)
- partialPlanPostgresL :: Lens' PartialPlan PartialPostgresPlan
- resourcesDataDirL :: Lens' Resources DirectoryType
- resourcesPlanL :: Lens' Resources Plan
- resourcesSocketL :: Lens' Resources SocketClass
- configDataDirL :: Lens' Config PartialDirectoryType
- configPlanL :: Lens' Config PartialPlan
- configPortL :: Lens' Config (Last (Maybe Int))
- configSocketL :: Lens' Config PartialSocketClass
- partialCommandLineArgsIndexBasedL :: Lens' PartialCommandLineArgs (Map Int String)
- partialCommandLineArgsKeyBasedL :: Lens' PartialCommandLineArgs (Map String (Maybe String))
Documentation
data PartialEnvVars Source #
The environment variables can be declared to inherit from the running process or they can be specifically added.
Instances
completePartialEnvVars :: [(String, String)] -> PartialEnvVars -> Either [String] [(String, String)] Source #
Combine the current environment
(if indicated by partialEnvVarsInherit
)
with partialEnvVarsSpecific
data PartialCommandLineArgs Source #
A type to help combine command line arguments.
PartialCommandLineArgs | |
|
Instances
completeCommandLineArgs :: PartialCommandLineArgs -> [String] Source #
This convert the PartialCommandLineArgs
to '
data PartialProcessConfig Source #
The monoidial version of ProcessConfig
. Used to combine overrides with
defaults when creating a ProcessConfig
.
PartialProcessConfig | |
|
Instances
standardProcessConfig :: PartialProcessConfig Source #
The standardProcessConfig
sets the handles to stdin
, stdout
and
stderr
and inherits the environment variables from the calling
process.
completeProcessConfig :: [(String, String)] -> PartialProcessConfig -> Either [String] ProcessConfig Source #
Turn a PartialProcessConfig
into a ProcessConfig
. Fails if
any values are missing.
data DirectoryType Source #
A type to track whether a file is temporary and needs to be cleaned up.
Instances
Eq DirectoryType Source # | |
Defined in Database.Postgres.Temp.Internal.Partial (==) :: DirectoryType -> DirectoryType -> Bool # (/=) :: DirectoryType -> DirectoryType -> Bool # | |
Ord DirectoryType Source # | |
Defined in Database.Postgres.Temp.Internal.Partial compare :: DirectoryType -> DirectoryType -> Ordering # (<) :: DirectoryType -> DirectoryType -> Bool # (<=) :: DirectoryType -> DirectoryType -> Bool # (>) :: DirectoryType -> DirectoryType -> Bool # (>=) :: DirectoryType -> DirectoryType -> Bool # max :: DirectoryType -> DirectoryType -> DirectoryType # min :: DirectoryType -> DirectoryType -> DirectoryType # | |
Show DirectoryType Source # | |
Defined in Database.Postgres.Temp.Internal.Partial showsPrec :: Int -> DirectoryType -> ShowS # show :: DirectoryType -> String # showList :: [DirectoryType] -> ShowS # | |
Pretty DirectoryType Source # | |
Defined in Database.Postgres.Temp.Internal.Partial pretty :: DirectoryType -> Doc # prettyList :: [DirectoryType] -> Doc # |
toFilePath :: DirectoryType -> FilePath Source #
Get the file path of a DirectoryType
, regardless if it is a
Permanent
or Temporary
type.
data PartialDirectoryType Source #
The monoidial version of DirectoryType
. Used to combine overrides with
defaults when creating a DirectoryType
. The monoid instance treats
PTemporary
as mempty
and takes the last PPermanent
value.
PPermanent FilePath | A permanent file that should not be generated. |
PTemporary | A temporary file that needs to generated. |
Instances
cleanupDirectoryType :: DirectoryType -> IO () Source #
data SocketClass Source #
A type for configuring the listening address of the postgres
process.
postgres
can listen on several types of sockets simulatanously but we
don't support that behavior. One can either listen on a IP based socket
or a UNIX domain socket.
IpSocket String | IP socket type. The |
UnixSocket DirectoryType | UNIX domain socket |
Instances
socketClassToConfig :: SocketClass -> [String] Source #
Create the extra config lines for listening based on the SocketClass
socketClassToHostFlag :: SocketClass -> [(String, Maybe String)] Source #
Many processes require a "host" flag. We can generate one from the
SocketClass
.
socketClassToHost :: SocketClass -> String Source #
Get the IP address, host name or UNIX domain socket directory
as a String
data PartialSocketClass Source #
The monoidial version of SocketClass
. Used to combine overrides with
defaults when creating a SocketClass
. The monoid instance treats
'PUnixSocket mempty' as mempty
and combines the
PIpSocket (Last String) | The monoid for combining IP address configuration |
PUnixSocket PartialDirectoryType | The monoid for combining UNIX socket configuration |
Instances
setupPartialSocketClass :: PartialSocketClass -> IO SocketClass Source #
Turn a PartialSocketClass
to a SocketClass
. If the PIpSocket
is
Nothing
default to "127.0.0.1". If the is a PUnixSocket
optionally create a temporary directory if configured to do so.
cleanupSocketConfig :: SocketClass -> IO () Source #
Cleanup the UNIX socket temporary directory if one was created.
data PartialPostgresPlan Source #
postgres
process config and corresponding client connection
Options
.
PartialPostgresPlan | |
|
Instances
completePostgresPlan :: [(String, String)] -> PartialPostgresPlan -> Either [String] PostgresPlan Source #
Turn a PartialPostgresPlan
into a PostgresPlan
. Fails if any
values are missing.
data PartialPlan Source #
The monoidial version of Plan
. Used to combine overrides with defaults
when creating a plan.
Instances
completePlan :: [(String, String)] -> PartialPlan -> Either [String] Plan Source #
Turn a PartialPlan
into a Plan
. Fails if any values are missing.
Resources
holds a description of the temporary folders (if there are any)
and includes the final Plan
that can be used with startPlan
.
See setupConfig
for an example of how to create a Resources
.
Resources | |
|
makeResourcesDataDirPermanent :: Resources -> Resources Source #
Make the resourcesDataDir
Permanent
so it will not
get cleaned up.
The high level options for overriding default behavior.
Config | |
|
Instances
Generic Config Source # | |
Semigroup Config Source # | |
Monoid Config Source # | |
Pretty Config Source # | |
Defined in Database.Postgres.Temp.Internal.Partial | |
type Rep Config Source # | |
Defined in Database.Postgres.Temp.Internal.Partial type Rep Config = D1 (MetaData "Config" "Database.Postgres.Temp.Internal.Partial" "tmp-postgres-1.7.1.0-Fl2f8QVtDW2J2btYcu2iIC" False) (C1 (MetaCons "Config" PrefixI True) ((S1 (MetaSel (Just "configPlan") NoSourceUnpackedness NoSourceStrictness DecidedLazy) (Rec0 PartialPlan) :*: S1 (MetaSel (Just "configSocket") NoSourceUnpackedness NoSourceStrictness DecidedLazy) (Rec0 PartialSocketClass)) :*: (S1 (MetaSel (Just "configDataDir") NoSourceUnpackedness NoSourceStrictness DecidedLazy) (Rec0 PartialDirectoryType) :*: S1 (MetaSel (Just "configPort") NoSourceUnpackedness NoSourceStrictness DecidedLazy) (Rec0 (Last (Maybe Int)))))) |
:: Bool | Make |
-> Bool | Make |
-> Int | port |
-> SocketClass | Whether to listen on a IP address or UNIX domain socket |
-> FilePath | The |
-> PartialPlan |
Create a PartialPlan
that sets the command line options of all processes
(initdb
, postgres
and createdb
) using a
Create all the temporary resources from a Config
. This also combines the
PartialPlan
from toPlan
with the extraConfig
passed in.
cleanupConfig :: Resources -> IO () Source #
Free the temporary resources created by setupConfig
optionsToConfig :: Options -> Config Source #
partialEnvVarsInheritL :: Lens' PartialEnvVars (Last Bool) Source #
Lens for partialEnvVarsInherit
partialEnvVarsSpecificL :: Lens' PartialEnvVars (Map String String) Source #
Lens for partialEnvVarsSpecific
partialProcessConfigCmdLineL :: Lens' PartialProcessConfig PartialCommandLineArgs Source #
Lens for partialProcessConfigCmdLine
partialProcessConfigEnvVarsL :: Lens' PartialProcessConfig PartialEnvVars Source #
Lens for partialProcessConfigEnvVars
partialProcessConfigStdErrL :: Lens' PartialProcessConfig (Last Handle) Source #
Lens for partialProcessConfigStdErr
partialProcessConfigStdInL :: Lens' PartialProcessConfig (Last Handle) Source #
Lens for partialProcessConfigStdIn
partialProcessConfigStdOutL :: Lens' PartialProcessConfig (Last Handle) Source #
Lens for partialProcessConfigStdOut
partialPostgresPlanClientConfigL :: Lens' PartialPostgresPlan Options Source #
Lens for partialPostgresPlanClientConfig
partialPostgresPlanProcessConfigL :: Lens' PartialPostgresPlan PartialProcessConfig Source #
Lens for partialPostgresPlanProcessConfig
partialPlanConfigL :: Lens' PartialPlan [String] Source #
Lens for partialPlanConfig
partialPlanCreateDbL :: Lens' PartialPlan (Maybe PartialProcessConfig) Source #
Lens for partialPlanCreateDb
partialPlanDataDirectoryL :: Lens' PartialPlan (Last String) Source #
Lens for partialPlanDataDirectory
partialPlanInitDbL :: Lens' PartialPlan (Maybe PartialProcessConfig) Source #
Lens for partialPlanInitDb
partialPlanLoggerL :: Lens' PartialPlan (Last Logger) Source #
Lens for partialPlanLogger
resourcesDataDirL :: Lens' Resources DirectoryType Source #
Lens for resourcesDataDir
resourcesPlanL :: Lens' Resources Plan Source #
Lens for resourcesPlan
resourcesSocketL :: Lens' Resources SocketClass Source #
Lens for resourcesSocket
configDataDirL :: Lens' Config PartialDirectoryType Source #
Lens for configDataDir
configPlanL :: Lens' Config PartialPlan Source #
Lens for configPlan
configPortL :: Lens' Config (Last (Maybe Int)) Source #
Lens for configPort
configSocketL :: Lens' Config PartialSocketClass Source #
Lens for configSocket