2022-04-22 16:38:35 +03:00
|
|
|
-- | Stuff gutted from Translate.Select
|
2022-04-22 20:18:20 +03:00
|
|
|
module Hasura.Backends.Postgres.Translate.Select.Internal.JoinTree
|
|
|
|
( withWriteJoinTree,
|
|
|
|
withWriteObjectRelation,
|
|
|
|
withWriteArrayRelation,
|
|
|
|
withWriteArrayConnection,
|
|
|
|
withWriteComputedFieldTableSet,
|
|
|
|
)
|
|
|
|
where
|
2022-04-22 16:38:35 +03:00
|
|
|
|
|
|
|
import Control.Monad.Writer.Strict
|
2023-04-26 18:42:13 +03:00
|
|
|
import Data.HashMap.Strict qualified as HashMap
|
2022-04-22 16:38:35 +03:00
|
|
|
import Hasura.Backends.Postgres.SQL.DML qualified as S
|
|
|
|
import Hasura.Backends.Postgres.Translate.Types
|
|
|
|
import Hasura.Prelude
|
|
|
|
|
2023-01-27 17:36:35 +03:00
|
|
|
-- | This is the lowest level function which deals with @MonadWriter SelectWriter@, which contains @JoinTree@ whose
|
2022-04-22 16:38:35 +03:00
|
|
|
-- purpose is to essentially create the selection tree across relationships.
|
|
|
|
--
|
|
|
|
-- Each type of relationship uses a different kind of update function; see
|
|
|
|
-- 'withWriteObjectRelation', 'withWriteArrayRelation', 'withWriteArrayConnection',
|
|
|
|
-- and 'withWriteComputedFieldTableSet'.
|
|
|
|
--
|
|
|
|
-- See the definition of 'JoinTree' for details before diving further
|
|
|
|
-- (particularly its components and Monoid instance).
|
|
|
|
withWriteJoinTree ::
|
2023-01-27 17:36:35 +03:00
|
|
|
(MonadWriter SelectWriter m) =>
|
2022-04-22 16:38:35 +03:00
|
|
|
(JoinTree -> b -> JoinTree) ->
|
|
|
|
m (a, b) ->
|
|
|
|
m a
|
|
|
|
withWriteJoinTree joinTreeUpdater action =
|
|
|
|
pass $ do
|
|
|
|
(out, result) <- action
|
2023-01-27 17:36:35 +03:00
|
|
|
let fromSelectWriter =
|
|
|
|
mapJoinTree (`joinTreeUpdater` result)
|
|
|
|
pure (out, fromSelectWriter)
|
|
|
|
|
|
|
|
-- | change the `JoinTree` inside a `SelectWriter`
|
|
|
|
mapJoinTree :: (JoinTree -> JoinTree) -> SelectWriter -> SelectWriter
|
|
|
|
mapJoinTree f sw = sw {_swJoinTree = f (_swJoinTree sw)}
|
2022-04-22 16:38:35 +03:00
|
|
|
|
|
|
|
withWriteObjectRelation ::
|
2023-01-27 17:36:35 +03:00
|
|
|
(MonadWriter SelectWriter m) =>
|
2022-04-22 16:38:35 +03:00
|
|
|
m
|
|
|
|
( ObjectRelationSource,
|
2023-04-26 18:42:13 +03:00
|
|
|
HashMap.HashMap S.ColumnAlias S.SQLExp,
|
2022-04-22 16:38:35 +03:00
|
|
|
a
|
|
|
|
) ->
|
|
|
|
m a
|
|
|
|
withWriteObjectRelation action =
|
|
|
|
withWriteJoinTree updateJoinTree $ do
|
|
|
|
(source, nodeExtractors, out) <- action
|
|
|
|
pure (out, (source, nodeExtractors))
|
|
|
|
where
|
|
|
|
updateJoinTree joinTree (source, nodeExtractors) =
|
|
|
|
let selectNode = SelectNode nodeExtractors joinTree
|
2023-04-26 18:42:13 +03:00
|
|
|
in mempty {_jtObjectRelations = HashMap.singleton source selectNode}
|
2022-04-22 16:38:35 +03:00
|
|
|
|
|
|
|
withWriteArrayRelation ::
|
2023-01-27 17:36:35 +03:00
|
|
|
(MonadWriter SelectWriter m) =>
|
2022-04-22 16:38:35 +03:00
|
|
|
m
|
|
|
|
( ArrayRelationSource,
|
|
|
|
S.Extractor,
|
2023-04-26 18:42:13 +03:00
|
|
|
HashMap.HashMap S.ColumnAlias S.SQLExp,
|
2022-04-22 16:38:35 +03:00
|
|
|
a
|
|
|
|
) ->
|
|
|
|
m a
|
|
|
|
withWriteArrayRelation action =
|
|
|
|
withWriteJoinTree updateJoinTree $ do
|
|
|
|
(source, topExtractor, nodeExtractors, out) <- action
|
|
|
|
pure (out, (source, topExtractor, nodeExtractors))
|
|
|
|
where
|
|
|
|
updateJoinTree joinTree (source, topExtractor, nodeExtractors) =
|
|
|
|
let arraySelectNode =
|
|
|
|
MultiRowSelectNode [topExtractor] $
|
|
|
|
SelectNode nodeExtractors joinTree
|
2023-04-26 18:42:13 +03:00
|
|
|
in mempty {_jtArrayRelations = HashMap.singleton source arraySelectNode}
|
2022-04-22 16:38:35 +03:00
|
|
|
|
|
|
|
withWriteArrayConnection ::
|
2023-01-27 17:36:35 +03:00
|
|
|
(MonadWriter SelectWriter m) =>
|
2022-04-22 16:38:35 +03:00
|
|
|
m
|
|
|
|
( ArrayConnectionSource,
|
|
|
|
S.Extractor,
|
2023-04-26 18:42:13 +03:00
|
|
|
HashMap.HashMap S.ColumnAlias S.SQLExp,
|
2022-04-22 16:38:35 +03:00
|
|
|
a
|
|
|
|
) ->
|
|
|
|
m a
|
|
|
|
withWriteArrayConnection action =
|
|
|
|
withWriteJoinTree updateJoinTree $ do
|
|
|
|
(source, topExtractor, nodeExtractors, out) <- action
|
|
|
|
pure (out, (source, topExtractor, nodeExtractors))
|
|
|
|
where
|
|
|
|
updateJoinTree joinTree (source, topExtractor, nodeExtractors) =
|
|
|
|
let arraySelectNode =
|
|
|
|
MultiRowSelectNode [topExtractor] $
|
|
|
|
SelectNode nodeExtractors joinTree
|
2023-04-26 18:42:13 +03:00
|
|
|
in mempty {_jtArrayConnections = HashMap.singleton source arraySelectNode}
|
2022-04-22 16:38:35 +03:00
|
|
|
|
|
|
|
withWriteComputedFieldTableSet ::
|
2023-01-27 17:36:35 +03:00
|
|
|
(MonadWriter SelectWriter m) =>
|
2022-04-22 16:38:35 +03:00
|
|
|
m
|
|
|
|
( ComputedFieldTableSetSource,
|
|
|
|
S.Extractor,
|
2023-04-26 18:42:13 +03:00
|
|
|
HashMap.HashMap S.ColumnAlias S.SQLExp,
|
2022-04-22 16:38:35 +03:00
|
|
|
a
|
|
|
|
) ->
|
|
|
|
m a
|
|
|
|
withWriteComputedFieldTableSet action =
|
|
|
|
withWriteJoinTree updateJoinTree $ do
|
|
|
|
(source, topExtractor, nodeExtractors, out) <- action
|
|
|
|
pure (out, (source, topExtractor, nodeExtractors))
|
|
|
|
where
|
|
|
|
updateJoinTree joinTree (source, topExtractor, nodeExtractors) =
|
|
|
|
let selectNode = MultiRowSelectNode [topExtractor] $ SelectNode nodeExtractors joinTree
|
2023-04-26 18:42:13 +03:00
|
|
|
in mempty {_jtComputedFieldTableSets = HashMap.singleton source selectNode}
|