module Effectful.Opaleye
(
Opaleye (..)
, runSelect
, runSelectI
, runSelectExplicit
, runSelectFold
, runSelectFoldExplicit
, runInsert
, runDelete
, runUpdate
, runOpaleyeWithConnection
, runOpaleyeWithConnectionCounting
, runOpaleyeConnection
, runOpaleyeConnectionCounting
, SQLOperationCounts (..)
, withCounts
, printCounts
)
where
import Data.Profunctor.Product.Default
import qualified Database.PostgreSQL.Simple as PSQL
import Effectful
import Effectful.Dispatch.Dynamic
import Effectful.Opaleye.Count
import Effectful.Opaleye.Effect
import qualified Effectful.PostgreSQL.Connection as Conn
import Effectful.State.Static.Shared
import qualified Opaleye as O
import qualified Opaleye.Internal.Inferrable as O
runSelect ::
(HasCallStack, Opaleye :> es, Default O.FromFields fields haskells) =>
O.Select fields ->
Eff es [haskells]
runSelect :: forall (es :: [Effect]) fields haskells.
(HasCallStack, Opaleye :> es,
Default FromFields fields haskells) =>
Select fields -> Eff es [haskells]
runSelect = FromFields fields haskells -> Select fields -> Eff es [haskells]
forall fields haskells (es :: [Effect]).
(HasCallStack, Opaleye :> es) =>
FromFields fields haskells -> Select fields -> Eff es [haskells]
runSelectExplicit FromFields fields haskells
forall (p :: * -> * -> *) a b. Default p a b => p a b
def
runSelectFold ::
(HasCallStack, Opaleye :> es, Default O.FromFields fields haskells) =>
O.Select fields ->
b ->
(b -> haskells -> Eff es b) ->
Eff es b
runSelectFold :: forall (es :: [Effect]) fields haskells b.
(HasCallStack, Opaleye :> es,
Default FromFields fields haskells) =>
Select fields -> b -> (b -> haskells -> Eff es b) -> Eff es b
runSelectFold = FromFields fields haskells
-> Select fields -> b -> (b -> haskells -> Eff es b) -> Eff es b
forall fields haskells b (es :: [Effect]).
(HasCallStack, Opaleye :> es) =>
FromFields fields haskells
-> Select fields -> b -> (b -> haskells -> Eff es b) -> Eff es b
runSelectFoldExplicit FromFields fields haskells
forall (p :: * -> * -> *) a b. Default p a b => p a b
def
runSelectI ::
(HasCallStack, Opaleye :> es, Default (O.Inferrable O.FromFields) fields haskells) =>
O.Select fields ->
Eff es [haskells]
runSelectI :: forall (es :: [Effect]) fields haskells.
(HasCallStack, Opaleye :> es,
Default (Inferrable FromFields) fields haskells) =>
Select fields -> Eff es [haskells]
runSelectI = FromFields fields haskells -> Select fields -> Eff es [haskells]
forall fields haskells (es :: [Effect]).
(HasCallStack, Opaleye :> es) =>
FromFields fields haskells -> Select fields -> Eff es [haskells]
runSelectExplicit (Inferrable FromFields fields haskells -> FromFields fields haskells
forall (p :: * -> * -> *) a b. Inferrable p a b -> p a b
O.runInferrable Inferrable FromFields fields haskells
forall (p :: * -> * -> *) a b. Default p a b => p a b
def)
runOpaleyeWithConnection ::
(HasCallStack, Conn.WithConnection :> es, IOE :> es) =>
Eff (Opaleye : es) a ->
Eff es a
runOpaleyeWithConnection :: forall (es :: [Effect]) a.
(HasCallStack, WithConnection :> es, IOE :> es) =>
Eff (Opaleye : es) a -> Eff es a
runOpaleyeWithConnection = EffectHandler Opaleye es -> Eff (Opaleye : es) a -> Eff es a
forall (e :: Effect) (es :: [Effect]) a.
(DispatchOf e ~ 'Dynamic) =>
EffectHandler e es -> Eff (e : es) a -> Eff es a
interpret (EffectHandler Opaleye es -> Eff (Opaleye : es) a -> Eff es a)
-> EffectHandler Opaleye es -> Eff (Opaleye : es) a -> Eff es a
forall a b. (a -> b) -> a -> b
$ \LocalEnv localEs es
env -> \case
RunSelectExplicit FromFields fields haskells
ff Select fields
sel -> (Connection -> Eff es a) -> Eff es a
forall a (es :: [Effect]).
(HasCallStack, WithConnection :> es) =>
(Connection -> Eff es a) -> Eff es a
Conn.withConnection ((Connection -> Eff es a) -> Eff es a)
-> (Connection -> Eff es a) -> Eff es a
forall a b. (a -> b) -> a -> b
$ \Connection
conn -> IO a -> Eff es a
forall a. IO a -> Eff es a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO a -> Eff es a) -> IO a -> Eff es a
forall a b. (a -> b) -> a -> b
$ FromFields fields haskells
-> Connection -> Select fields -> IO [haskells]
forall fields haskells.
FromFields fields haskells
-> Connection -> Select fields -> IO [haskells]
O.runSelectExplicit FromFields fields haskells
ff Connection
conn Select fields
sel
RunSelectFoldExplicit FromFields fields haskells
ff Select fields
sel a
initial a -> haskells -> Eff localEs a
foldFn ->
(Connection -> Eff es a) -> Eff es a
forall a (es :: [Effect]).
(HasCallStack, WithConnection :> es) =>
(Connection -> Eff es a) -> Eff es a
Conn.withConnection ((Connection -> Eff es a) -> Eff es a)
-> (Connection -> Eff es a) -> Eff es a
forall a b. (a -> b) -> a -> b
$ \Connection
conn ->
LocalEnv localEs es
-> ((forall r. Eff localEs r -> IO r) -> IO a) -> Eff es a
forall (es :: [Effect]) (handlerEs :: [Effect])
(localEs :: [Effect]) a.
(HasCallStack, SharedSuffix es handlerEs, IOE :> es) =>
LocalEnv localEs handlerEs
-> ((forall r. Eff localEs r -> IO r) -> IO a) -> Eff es a
localSeqUnliftIO LocalEnv localEs es
env (((forall r. Eff localEs r -> IO r) -> IO a) -> Eff es a)
-> ((forall r. Eff localEs r -> IO r) -> IO a) -> Eff es a
forall a b. (a -> b) -> a -> b
$ \forall r. Eff localEs r -> IO r
unlift ->
IO a -> IO a
forall a. IO a -> IO a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO a -> IO a) -> IO a -> IO a
forall a b. (a -> b) -> a -> b
$ FromFields fields haskells
-> Connection
-> Select fields
-> a
-> (a -> haskells -> IO a)
-> IO a
forall fields haskells b.
FromFields fields haskells
-> Connection
-> Select fields
-> b
-> (b -> haskells -> IO b)
-> IO b
O.runSelectFoldExplicit FromFields fields haskells
ff Connection
conn Select fields
sel a
initial (\a
acc haskells
new -> Eff localEs a -> IO a
forall r. Eff localEs r -> IO r
unlift (Eff localEs a -> IO a) -> Eff localEs a -> IO a
forall a b. (a -> b) -> a -> b
$ a -> haskells -> Eff localEs a
foldFn a
acc haskells
new)
RunInsert Insert a
sel -> (Connection -> Eff es a) -> Eff es a
forall a (es :: [Effect]).
(HasCallStack, WithConnection :> es) =>
(Connection -> Eff es a) -> Eff es a
Conn.withConnection ((Connection -> Eff es a) -> Eff es a)
-> (Connection -> Eff es a) -> Eff es a
forall a b. (a -> b) -> a -> b
$ \Connection
conn -> IO a -> Eff es a
forall a. IO a -> Eff es a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO a -> Eff es a) -> IO a -> Eff es a
forall a b. (a -> b) -> a -> b
$ Connection -> Insert a -> IO a
forall haskells. Connection -> Insert haskells -> IO haskells
O.runInsert Connection
conn Insert a
sel
RunDelete Delete a
sel -> (Connection -> Eff es a) -> Eff es a
forall a (es :: [Effect]).
(HasCallStack, WithConnection :> es) =>
(Connection -> Eff es a) -> Eff es a
Conn.withConnection ((Connection -> Eff es a) -> Eff es a)
-> (Connection -> Eff es a) -> Eff es a
forall a b. (a -> b) -> a -> b
$ \Connection
conn -> IO a -> Eff es a
forall a. IO a -> Eff es a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO a -> Eff es a) -> IO a -> Eff es a
forall a b. (a -> b) -> a -> b
$ Connection -> Delete a -> IO a
forall haskells. Connection -> Delete haskells -> IO haskells
O.runDelete Connection
conn Delete a
sel
RunUpdate Update a
sel -> (Connection -> Eff es a) -> Eff es a
forall a (es :: [Effect]).
(HasCallStack, WithConnection :> es) =>
(Connection -> Eff es a) -> Eff es a
Conn.withConnection ((Connection -> Eff es a) -> Eff es a)
-> (Connection -> Eff es a) -> Eff es a
forall a b. (a -> b) -> a -> b
$ \Connection
conn -> IO a -> Eff es a
forall a. IO a -> Eff es a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO a -> Eff es a) -> IO a -> Eff es a
forall a b. (a -> b) -> a -> b
$ Connection -> Update a -> IO a
forall haskells. Connection -> Update haskells -> IO haskells
O.runUpdate Connection
conn Update a
sel
runOpaleyeConnection ::
(HasCallStack, IOE :> es) =>
PSQL.Connection ->
Eff (Opaleye : es) a ->
Eff es a
runOpaleyeConnection :: forall (es :: [Effect]) a.
(HasCallStack, IOE :> es) =>
Connection -> Eff (Opaleye : es) a -> Eff es a
runOpaleyeConnection Connection
conn = EffectHandler Opaleye es -> Eff (Opaleye : es) a -> Eff es a
forall (e :: Effect) (es :: [Effect]) a.
(DispatchOf e ~ 'Dynamic) =>
EffectHandler e es -> Eff (e : es) a -> Eff es a
interpret (EffectHandler Opaleye es -> Eff (Opaleye : es) a -> Eff es a)
-> EffectHandler Opaleye es -> Eff (Opaleye : es) a -> Eff es a
forall a b. (a -> b) -> a -> b
$ \LocalEnv localEs es
env -> \case
RunSelectExplicit FromFields fields haskells
ff Select fields
sel -> IO a -> Eff es a
forall a. IO a -> Eff es a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO a -> Eff es a) -> IO a -> Eff es a
forall a b. (a -> b) -> a -> b
$ FromFields fields haskells
-> Connection -> Select fields -> IO [haskells]
forall fields haskells.
FromFields fields haskells
-> Connection -> Select fields -> IO [haskells]
O.runSelectExplicit FromFields fields haskells
ff Connection
conn Select fields
sel
RunSelectFoldExplicit FromFields fields haskells
ff Select fields
sel a
initial a -> haskells -> Eff localEs a
foldFn ->
LocalEnv localEs es
-> ((forall r. Eff localEs r -> IO r) -> IO a) -> Eff es a
forall (es :: [Effect]) (handlerEs :: [Effect])
(localEs :: [Effect]) a.
(HasCallStack, SharedSuffix es handlerEs, IOE :> es) =>
LocalEnv localEs handlerEs
-> ((forall r. Eff localEs r -> IO r) -> IO a) -> Eff es a
localSeqUnliftIO LocalEnv localEs es
env (((forall r. Eff localEs r -> IO r) -> IO a) -> Eff es a)
-> ((forall r. Eff localEs r -> IO r) -> IO a) -> Eff es a
forall a b. (a -> b) -> a -> b
$ \forall r. Eff localEs r -> IO r
unlift ->
IO a -> IO a
forall a. IO a -> IO a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO a -> IO a) -> IO a -> IO a
forall a b. (a -> b) -> a -> b
$ FromFields fields haskells
-> Connection
-> Select fields
-> a
-> (a -> haskells -> IO a)
-> IO a
forall fields haskells b.
FromFields fields haskells
-> Connection
-> Select fields
-> b
-> (b -> haskells -> IO b)
-> IO b
O.runSelectFoldExplicit FromFields fields haskells
ff Connection
conn Select fields
sel a
initial (\a
acc haskells
new -> Eff localEs a -> IO a
forall r. Eff localEs r -> IO r
unlift (Eff localEs a -> IO a) -> Eff localEs a -> IO a
forall a b. (a -> b) -> a -> b
$ a -> haskells -> Eff localEs a
foldFn a
acc haskells
new)
RunInsert Insert a
sel -> IO a -> Eff es a
forall a. IO a -> Eff es a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO a -> Eff es a) -> IO a -> Eff es a
forall a b. (a -> b) -> a -> b
$ Connection -> Insert a -> IO a
forall haskells. Connection -> Insert haskells -> IO haskells
O.runInsert Connection
conn Insert a
sel
RunDelete Delete a
sel -> IO a -> Eff es a
forall a. IO a -> Eff es a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO a -> Eff es a) -> IO a -> Eff es a
forall a b. (a -> b) -> a -> b
$ Connection -> Delete a -> IO a
forall haskells. Connection -> Delete haskells -> IO haskells
O.runDelete Connection
conn Delete a
sel
RunUpdate Update a
sel -> IO a -> Eff es a
forall a. IO a -> Eff es a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO a -> Eff es a) -> IO a -> Eff es a
forall a b. (a -> b) -> a -> b
$ Connection -> Update a -> IO a
forall haskells. Connection -> Update haskells -> IO haskells
O.runUpdate Connection
conn Update a
sel
runOpaleyeWithConnectionCounting ::
forall a es.
(HasCallStack, State SQLOperationCounts :> es, Conn.WithConnection :> es, IOE :> es) =>
Eff (Opaleye : es) a ->
Eff es a
runOpaleyeWithConnectionCounting :: forall a (es :: [Effect]).
(HasCallStack, State SQLOperationCounts :> es,
WithConnection :> es, IOE :> es) =>
Eff (Opaleye : es) a -> Eff es a
runOpaleyeWithConnectionCounting = Eff (Opaleye : es) a -> Eff es a
forall (es :: [Effect]) a.
(HasCallStack, WithConnection :> es, IOE :> es) =>
Eff (Opaleye : es) a -> Eff es a
runOpaleyeWithConnection (Eff (Opaleye : es) a -> Eff es a)
-> (Eff (Opaleye : es) a -> Eff (Opaleye : es) a)
-> Eff (Opaleye : es) a
-> Eff es a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Eff (Opaleye : es) a -> Eff (Opaleye : es) a
forall a (es :: [Effect]).
(HasCallStack, State SQLOperationCounts :> es) =>
Eff (Opaleye : es) a -> Eff (Opaleye : es) a
opaleyeAddCounting
runOpaleyeConnectionCounting ::
(HasCallStack, State SQLOperationCounts :> es, IOE :> es) =>
PSQL.Connection ->
Eff (Opaleye : es) a ->
Eff es a
runOpaleyeConnectionCounting :: forall (es :: [Effect]) a.
(HasCallStack, State SQLOperationCounts :> es, IOE :> es) =>
Connection -> Eff (Opaleye : es) a -> Eff es a
runOpaleyeConnectionCounting Connection
conn = Connection -> Eff (Opaleye : es) a -> Eff es a
forall (es :: [Effect]) a.
(HasCallStack, IOE :> es) =>
Connection -> Eff (Opaleye : es) a -> Eff es a
runOpaleyeConnection Connection
conn (Eff (Opaleye : es) a -> Eff es a)
-> (Eff (Opaleye : es) a -> Eff (Opaleye : es) a)
-> Eff (Opaleye : es) a
-> Eff es a
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Eff (Opaleye : es) a -> Eff (Opaleye : es) a
forall a (es :: [Effect]).
(HasCallStack, State SQLOperationCounts :> es) =>
Eff (Opaleye : es) a -> Eff (Opaleye : es) a
opaleyeAddCounting