{-| Module : Main.hs Description : Gargantext Import Corpus Copyright : (c) CNRS, 2017-Present License : AGPL + CECILL v3 Maintainer : team@gargantext.org Stability : experimental Portability : POSIX Import a corpus binary. -} {-# LANGUAGE Strict #-} module Main where import Data.Text qualified as Text import Gargantext.API.Admin.EnvTypes (DevEnv(..), DevJobHandle(..)) import Gargantext.API.Dev (withDevEnv, runCmdGargDev) import Gargantext.API.Errors.Types ( BackendInternalError ) import Gargantext.API.Node () -- instances import Gargantext.Core (Lang(..)) import Gargantext.Core.Text.Corpus.Parsers (FileFormat(..), FileType(..)) import Gargantext.Core.Types.Individu (User(..)) import Gargantext.Core.Types.Query (Limit) import Gargantext.Database.Action.Flow (flowCorpusFile, flowAnnuaire, TermType(..)) import Gargantext.Database.Action.Flow.Types (FlowCmdM) import Gargantext.Database.Admin.Types.Node (CorpusId) import Gargantext.Database.Query.Tree.Root (MkCorpusUser(MkCorpusUserNormalCorpusName)) import Gargantext.Prelude import Gargantext.Utils.Jobs.Monad ( MonadJobStatus, JobHandle ) main :: IO () main = do [fun, user, name, iniPath, limit, corpusPath] <- getArgs --{- let --tt = (Unsupervised EN 6 0 Nothing) tt = (Multi EN) format = TsvGargV3 -- TsvHal --WOS limit' = case (readMaybe limit :: Maybe Limit) of Nothing -> panicTrace $ "Cannot read limit: " <> (Text.pack limit) Just l -> l corpus :: forall m. (FlowCmdM DevEnv BackendInternalError m, MonadJobStatus m, JobHandle m ~ DevJobHandle) => m CorpusId mkCorpusUser = MkCorpusUserNormalCorpusName (UserName $ cs user) (cs name :: Text) corpus = flowCorpusFile mkCorpusUser limit' tt format Plain corpusPath Nothing DevJobHandle corpusTsvHal :: forall m. (FlowCmdM DevEnv BackendInternalError m, MonadJobStatus m, JobHandle m ~ DevJobHandle) => m CorpusId corpusTsvHal = flowCorpusFile mkCorpusUser limit' tt TsvHal Plain corpusPath Nothing DevJobHandle annuaire :: forall m. (FlowCmdM DevEnv BackendInternalError m, MonadJobStatus m, JobHandle m ~ DevJobHandle) => m CorpusId annuaire = flowAnnuaire (MkCorpusUserNormalCorpusName (UserName $ cs user) "Annuaire") (Multi EN) corpusPath DevJobHandle {- let debatCorpus :: forall m. FlowCmdM DevEnv BackendInternalError m => m CorpusId debatCorpus = do docs <- liftIO ( splitEvery 500 <$> take (read limit :: Int) <$> readFile corpusPath :: IO [[GrandDebatReference ]] ) flowCorpus (Text.pack user) (Text.pack name) (Multi FR) (map (map toHyperdataDocument) docs) --} withDevEnv iniPath $ \env -> do _ <- if fun == "corpus" then runCmdGargDev env corpus else pure 0 --(cs "false") _ <- if fun == "corpusTsvHal" then runCmdGargDev env corpusTsvHal else pure 0 --(cs "false") _ <- if fun == "annuaire" then runCmdGargDev env annuaire else pure 0 {- _ <- if corpusType == "csv" then runCmdDev env csvCorpus else if corpusType == "debat" then runCmdDev env debatCorpus else panic "corpusType unknown: try \"csv\" or \"debat\"" -} pure ()