{-| Module : Gargantext.API.Node.Contact Description : Copyright : (c) CNRS, 2017-Present License : AGPL + CECILL v3 Maintainer : team@gargantext.org Stability : experimental Portability : POSIX -} {-# OPTIONS_GHC -fno-warn-orphans #-} {-# LANGUAGE ConstraintKinds #-} {-# LANGUAGE KindSignatures #-} {-# LANGUAGE ScopedTypeVariables #-} {-# LANGUAGE TemplateHaskell #-} {-# LANGUAGE TypeFamilies #-} {-# LANGUAGE TypeOperators #-} module Gargantext.API.Node.Contact where import Conduit import Data.Aeson import Data.Either (Either(Right)) import Data.Maybe (Maybe(..)) import Data.Swagger import Data.Text (Text) import GHC.Generics (Generic) import Servant import Test.QuickCheck (elements) import Test.QuickCheck.Arbitrary import Gargantext.API.Admin.EnvTypes (Env, GargJob(..)) import Gargantext.API.Admin.Orchestrator.Types (JobLog(..), AsyncJobs) import Gargantext.API.Admin.Types (HasSettings) import Gargantext.API.Node import Gargantext.API.Prelude (GargError, GargM, simuLogs) import Gargantext.Core (Lang(..)) import Gargantext.Core.Text.Terms (TermType(..)) import Gargantext.Core.Types.Individu (User(..)) import Gargantext.Database.Action.Flow (flow) import Gargantext.Database.Action.Flow.Types (FlowCmdM) import Gargantext.Database.Admin.Types.Hyperdata (HyperdataAnnuaire(..), HyperdataContact) import Gargantext.Database.Admin.Types.Hyperdata.Contact (hyperdataContact) import Gargantext.Database.Admin.Types.Node import Gargantext.Prelude (($), {-printDebug,-}) import qualified Gargantext.Utils.Aeson as GUA import Gargantext.Utils.Jobs (serveJobsAPI, MonadJobStatus(..)) ------------------------------------------------------------------------ type API = "contact" :> Summary "Contact endpoint" :> API_Async :<|> Capture "contact_id" NodeId :> NodeNodeAPI HyperdataContact api :: UserId -> CorpusId -> ServerT API (GargM Env GargError) api uid cid = (api_async (RootId (NodeId uid)) cid) :<|> (nodeNodeAPI (Proxy :: Proxy HyperdataContact) uid cid) type API_Async = AsyncJobs JobLog '[JSON] AddContactParams JobLog ------------------------------------------------------------------------ data AddContactParams = AddContactParams { firstname :: !Text, lastname :: !Text } | AddContactParamsAdvanced { firstname :: !Text , lastname :: !Text -- TODO add others fields } deriving (Generic) ---------------------------------------------------------------------- api_async :: User -> NodeId -> ServerT API_Async (GargM Env GargError) api_async u nId = serveJobsAPI AddContactJob $ \jHandle p -> addContact u nId p jHandle addContact :: (HasSettings env, FlowCmdM env err m, MonadJobStatus m) => User -> NodeId -> AddContactParams -> JobHandle m -> m () addContact u nId (AddContactParams fn ln) jobHandle = do markStarted 2 jobHandle _ <- flow (Nothing :: Maybe HyperdataAnnuaire) u (Right [nId]) (Multi EN) Nothing (Just 1, yield $ hyperdataContact fn ln) jobHandle markComplete jobHandle addContact _uId _nId _p jobHandle = do simuLogs jobHandle 10 ------------------------------------------------------------------------ -- TODO unPrefix "pn_" FromJSON, ToJSON, ToSchema, adapt frontend. instance FromJSON AddContactParams where parseJSON = genericParseJSON (defaultOptions { sumEncoding = GUA.defaultTaggedObject }) instance ToJSON AddContactParams where toJSON = genericToJSON (defaultOptions { sumEncoding = GUA.defaultTaggedObject }) instance ToSchema AddContactParams instance Arbitrary AddContactParams where arbitrary = elements [AddContactParams "Pierre" "Dupont"] ------------------------------------------------------------------------