Update README.md
[gargantext.git] / src / Gargantext / Database / Schema / NodeNode.hs
index 08f36151a73f6cfc206aec5500058f5a066afb5b..dff5f28a1fa3e399d84787c3422dc108d4c9ca1d 100644 (file)
@@ -11,198 +11,53 @@ Here is a longer description of this module, containing some
 commentary with @some markup@.
 -}
 
-{-# OPTIONS_GHC -fno-warn-orphans #-}
-
 {-# LANGUAGE Arrows                 #-}
-{-# LANGUAGE FlexibleInstances      #-}
 {-# LANGUAGE FunctionalDependencies #-}
 {-# LANGUAGE QuasiQuotes            #-}
-{-# LANGUAGE MultiParamTypeClasses  #-}
-{-# LANGUAGE NoImplicitPrelude      #-}
-{-# LANGUAGE OverloadedStrings      #-}
-{-# LANGUAGE RankNTypes             #-}
 {-# LANGUAGE TemplateHaskell        #-}
 
 module Gargantext.Database.Schema.NodeNode where
 
-import Control.Lens (view, (^.))
-import qualified Database.PostgreSQL.Simple as PGS (Query, Only(..))
-import Database.PostgreSQL.Simple.Types (Values(..), QualifiedIdentifier(..))
-import Database.PostgreSQL.Simple.SqlQQ (sql)
-import Control.Lens.TH (makeLenses)
-import Data.Maybe (Maybe, catMaybes)
-import Data.Text (Text, splitOn)
-import Data.Profunctor.Product.TH (makeAdaptorAndInstance)
-import Gargantext.Database.Schema.Node 
 import Gargantext.Core.Types
-import Gargantext.Database.Utils
-import Gargantext.Database.Config (nodeTypeId)
-import Gargantext.Database.Types.Node (CorpusId, DocId)
+import Gargantext.Database.Schema.Prelude
 import Gargantext.Prelude
-import Opaleye
-import Control.Arrow (returnA)
-import qualified Opaleye as O
+
 
 data NodeNodePoly node1_id node2_id score cat
-                   = NodeNode { _nn_node1_id   :: node1_id
-                              , _nn_node2_id   :: node2_id
-                              , _nn_score      :: score
-                              , _nn_category   :: cat
+                   = NodeNode { _nn_node1_id   :: !node1_id
+                              , _nn_node2_id   :: !node2_id
+                              , _nn_score      :: !score
+                              , _nn_category   :: !cat
                               } deriving (Show)
 
-type NodeNodeWrite     = NodeNodePoly (Column (PGInt4))
-                                      (Column (PGInt4))
-                                      (Maybe  (Column (PGFloat8)))
-                                      (Maybe  (Column (PGInt4)))
+type NodeNodeWrite     = NodeNodePoly (Column (SqlInt4))
+                                      (Column (SqlInt4))
+                                      (Maybe  (Column (SqlFloat8)))
+                                      (Maybe  (Column (SqlInt4)))
 
-type NodeNodeRead      = NodeNodePoly (Column (PGInt4))
-                                      (Column (PGInt4))
-                                      (Column (PGFloat8))
-                                      (Column (PGInt4))
+type NodeNodeRead      = NodeNodePoly (Column (SqlInt4))
+                                      (Column (SqlInt4))
+                                      (Column (SqlFloat8))
+                                      (Column (SqlInt4))
 
-type NodeNodeReadNull  = NodeNodePoly (Column (Nullable PGInt4))
-                                      (Column (Nullable PGInt4))
-                                      (Column (Nullable PGFloat8))
-                                      (Column (Nullable PGInt4))
+type NodeNodeReadNull  = NodeNodePoly (Column (Nullable SqlInt4))
+                                      (Column (Nullable SqlInt4))
+                                      (Column (Nullable SqlFloat8))
+                                      (Column (Nullable SqlInt4))
 
-type NodeNode = NodeNodePoly Int Int (Maybe Double) (Maybe Int)
+type NodeNode = NodeNodePoly NodeId NodeId (Maybe Double) (Maybe Int)
 
 $(makeAdaptorAndInstance "pNodeNode" ''NodeNodePoly)
 makeLenses ''NodeNodePoly
 
 nodeNodeTable :: Table NodeNodeWrite NodeNodeRead
-nodeNodeTable  = Table "nodes_nodes" (pNodeNode
-                                NodeNode { _nn_node1_id = required "node1_id"
-                                         , _nn_node2_id = required "node2_id"
-                                         , _nn_score    = optional "score"
-                                         , _nn_category = optional "category"
-                                     }
-                                     )
-
-queryNodeNodeTable :: Query NodeNodeRead
-queryNodeNodeTable = queryTable nodeNodeTable
-
-
--- | not optimized (get all ngrams without filters)
-nodesNodes :: Cmd err [NodeNode]
-nodesNodes = runOpaQuery queryNodeNodeTable
-
-instance QueryRunnerColumnDefault (Nullable PGInt4) Int where
-    queryRunnerColumnDefault = fieldQueryRunnerColumn
-
-instance QueryRunnerColumnDefault (Nullable PGFloat8) Int where
-    queryRunnerColumnDefault = fieldQueryRunnerColumn
-
-instance QueryRunnerColumnDefault (Nullable PGFloat8) Double where
-    queryRunnerColumnDefault = fieldQueryRunnerColumn
-
-instance QueryRunnerColumnDefault PGFloat8 (Maybe Double) where
-    queryRunnerColumnDefault = fieldQueryRunnerColumn
-
-instance QueryRunnerColumnDefault PGInt4 (Maybe Int) where
-    queryRunnerColumnDefault = fieldQueryRunnerColumn
-
-
-------------------------------------------------------------------------
--- | Favorite management
-nodeNodeCategory :: CorpusId -> DocId -> Int -> Cmd err [Int]
-nodeNodeCategory cId dId c = map (\(PGS.Only a) -> a) <$> runPGSQuery favQuery (c,cId,dId)
-  where
-    favQuery :: PGS.Query
-    favQuery = [sql|UPDATE nodes_nodes SET category = ?
-               WHERE node1_id = ? AND node2_id = ?
-               RETURNING node2_id;
-               |]
-
-nodeNodesCategory :: [(CorpusId,DocId,Int)] -> Cmd err [Int]
-nodeNodesCategory inputData = map (\(PGS.Only a) -> a)
-                            <$> runPGSQuery catQuery (PGS.Only $ Values fields inputData)
-  where
-    fields = map (\t-> QualifiedIdentifier Nothing t) ["int4","int4","int4"]
-    catQuery :: PGS.Query
-    catQuery = [sql| UPDATE nodes_nodes as old SET
-                 category = new.category
-                 from (?) as new(node1_id,node2_id,category)
-                 WHERE old.node1_id = new.node1_id
-                 AND   old.node2_id = new.node2_id
-                 RETURNING new.node2_id
-                  |]
-
-------------------------------------------------------------------------
--- | TODO use UTCTime fast 
-selectDocsDates :: CorpusId -> Cmd err [Text]
-selectDocsDates cId = 
-                map (head' "selectDocsDates" . splitOn "-")
-               <$> catMaybes
-               <$> map (view hyperdataDocument_publication_date)
-               <$> selectDocs cId
-
-
-selectDocs :: CorpusId -> Cmd err [HyperdataDocument]
-selectDocs cId = runOpaQuery (queryDocs cId)
-
-queryDocs :: CorpusId -> O.Query (Column PGJsonb)
-queryDocs cId = proc () -> do
-  (n, nn) <- joinInCorpus -< ()
-  restrict -< nn^.nn_node1_id  .== (toNullable $ pgNodeId cId)
-  restrict -< nn^.nn_category  .>= (toNullable $ pgInt4 1)
-  restrict -< n^.node_typename .== (pgInt4 $ nodeTypeId NodeDocument)
-  returnA -< view (node_hyperdata) n
-
-
-selectDocNodes :: CorpusId -> Cmd err [Node HyperdataDocument]
-selectDocNodes cId = runOpaQuery (queryDocNodes cId)
-
-queryDocNodes :: CorpusId -> O.Query NodeRead
-queryDocNodes cId = proc () -> do
-  (n, nn) <- joinInCorpus -< ()
-  restrict -< nn^.nn_node1_id  .== (toNullable $ pgNodeId cId)
-  restrict -< nn^.nn_category  .>= (toNullable $ pgInt4 1)
-  restrict -< n^.node_typename .== (pgInt4 $ nodeTypeId NodeDocument)
-  returnA -<  n
-
-
-joinInCorpus :: O.Query (NodeRead, NodeNodeReadNull)
-joinInCorpus = leftJoin queryNodeTable queryNodeNodeTable cond
-  where
-    cond :: (NodeRead, NodeNodeRead) -> Column PGBool
-    cond (n, nn) = nn^.nn_node2_id .== (view node_id n)
-
-
-------------------------------------------------------------------------
--- | Trash management
-nodeToTrash :: CorpusId -> DocId -> Bool -> Cmd err [PGS.Only Int]
-nodeToTrash cId dId b = runPGSQuery trashQuery (b,cId,dId)
-  where
-    trashQuery :: PGS.Query
-    trashQuery = [sql|UPDATE nodes_nodes SET delete = ?
-                  WHERE node1_id = ? AND node2_id = ?
-                  RETURNING node2_id
-                  |]
-
--- | Trash Massive
-nodesToTrash :: [(CorpusId,DocId,Bool)] -> Cmd err [Int]
-nodesToTrash input = map (\(PGS.Only a) -> a)
-                        <$> runPGSQuery trashQuery (PGS.Only $ Values fields input)
-  where
-    fields = map (\t-> QualifiedIdentifier Nothing t) ["int4","int4","bool"]
-    trashQuery :: PGS.Query
-    trashQuery = [sql| UPDATE nodes_nodes as old SET
-                 delete = new.delete
-                 from (?) as new(node1_id,node2_id,delete)
-                 WHERE old.node1_id = new.node1_id
-                 AND   old.node2_id = new.node2_id
-                 RETURNING new.node2_id
-                  |]
+nodeNodeTable  =
+  Table "nodes_nodes"
+         ( pNodeNode
+           NodeNode { _nn_node1_id = requiredTableField "node1_id"
+                    , _nn_node2_id = requiredTableField "node2_id"
+                    , _nn_score    = optionalTableField "score"
+                    , _nn_category = optionalTableField "category"
+                    }
+                )
 
--- | /!\ Really remove nodes in the Corpus or Annuaire
-emptyTrash :: CorpusId -> Cmd err [PGS.Only Int]
-emptyTrash cId = runPGSQuery delQuery (PGS.Only cId)
-  where
-    delQuery :: PGS.Query
-    delQuery = [sql|DELETE from nodes_nodes n
-                    WHERE n.node1_id = ?
-                      AND n.delete = true
-                    RETURNING n.node2_id
-                |]
-------------------------------------------------------------------------