2 Module : Gargantext.Database.Query.Table.Node.Children
3 Description : Main requests of Node to the database
4 Copyright : (c) CNRS, 2017-Present
5 License : AGPL + CECILL v3
6 Maintainer : team@gargantext.org
7 Stability : experimental
11 {-# OPTIONS_GHC -fno-warn-name-shadowing #-}
12 {-# OPTIONS_GHC -fno-warn-orphans #-}
14 {-# LANGUAGE Arrows #-}
15 {-# LANGUAGE FlexibleInstances #-}
16 {-# LANGUAGE FlexibleContexts #-}
17 {-# LANGUAGE RankNTypes #-}
19 module Gargantext.Database.Query.Table.Node.Children
22 import Control.Arrow (returnA)
24 import Gargantext.Core.Types
25 import Gargantext.Database.Query.Filter
26 import Gargantext.Database.Query.Table.Node
27 import Gargantext.Database.Query.Table.NodeNode
28 import Gargantext.Database.Query.Table.Node.Contact (HyperdataContact)
29 import Gargantext.Database.Admin.Config (nodeTypeId)
30 import Gargantext.Database.Admin.Types.Node (pgNodeId)
31 import Gargantext.Database.Prelude
32 import Gargantext.Database.Schema.Node
35 getAllDocuments :: ParentId -> Cmd err (TableResult (Node HyperdataDocument))
36 getAllDocuments pId = getAllChildren pId (Proxy :: Proxy HyperdataDocument)
39 getAllContacts :: ParentId -> Cmd err (TableResult (Node HyperdataContact))
40 getAllContacts pId = getAllChildren pId (Proxy :: Proxy HyperdataContact)
43 getAllChildren :: JSONB a
47 -> Cmd err (NodeTableResult a)
48 getAllChildren pId p maybeNodeType = getChildren pId p maybeNodeType Nothing Nothing
50 getChildren :: JSONB a
56 -> Cmd err (NodeTableResult a)
57 getChildren pId _ maybeNodeType maybeOffset maybeLimit = do
59 $ limit' maybeLimit $ offset' maybeOffset
60 $ orderBy (asc _node_id)
63 docCount <- runCountOpaQuery query
65 pure $ TableResult { tr_docs = docs, tr_count = docCount }
68 query = selectChildren pId maybeNodeType
70 selectChildren :: ParentId
73 selectChildren parentId maybeNodeType = proc () -> do
74 row@(Node nId typeName _ parent_id _ _ _) <- queryNodeTable -< ()
75 (NodeNode n1id n2id _ _) <- queryNodeNodeTable -< ()
77 let nodeType = maybe 0 nodeTypeId maybeNodeType
78 restrict -< typeName .== pgInt4 nodeType
80 restrict -< (.||) (parent_id .== (pgNodeId parentId))
81 ( (.&&) (n1id .== pgNodeId parentId)