{-| Module : Gargantext.API.Count Description : Server API Copyright : (c) CNRS, 2017-Present License : AGPL + CECILL v3 Maintainer : team@gargantext.org Stability : experimental Portability : POSIX Count API part of Gargantext. -} {-# OPTIONS_GHC -fno-warn-name-shadowing #-} {-# LANGUAGE FlexibleContexts #-} {-# LANGUAGE NoImplicitPrelude #-} {-# LANGUAGE DataKinds #-} {-# LANGUAGE TemplateHaskell #-} {-# LANGUAGE TypeOperators #-} {-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE DeriveAnyClass #-} {-# LANGUAGE OverloadedStrings #-} {-# LANGUAGE RankNTypes #-} module Gargantext.API.Search where import Data.Aeson.TH (deriveJSON) import Data.Swagger import Data.Text (Text) import Data.Time (UTCTime) import GHC.Generics (Generic) import Gargantext.API.Prelude (GargServer) import Gargantext.Core.Utils.Prefix (unPrefix, unPrefixSwagger) import Gargantext.Database.Query.Facet import Gargantext.Database.Action.Search import Gargantext.Database.Admin.Types.Hyperdata (HyperdataDocument) import Gargantext.Database.Admin.Types.Node import Gargantext.Prelude import Servant import Test.QuickCheck (elements) import Test.QuickCheck.Arbitrary ----------------------------------------------------------------------- data SearchQuery = SearchQuery { sq_query :: [Text] } deriving (Generic) $(deriveJSON (unPrefix "sq_") ''SearchQuery) instance ToSchema SearchQuery where declareNamedSchema = genericDeclareNamedSchema (unPrefixSwagger "sq_") instance Arbitrary SearchQuery where arbitrary = elements [SearchQuery ["electrodes"]] ----------------------------------------------------------------------- data SearchDocResults = SearchDocResults { sdr_results :: [FacetDoc]} deriving (Generic) $(deriveJSON (unPrefix "sdr_") ''SearchDocResults) instance Arbitrary SearchDocResults where arbitrary = SearchDocResults <$> arbitrary instance ToSchema SearchDocResults where declareNamedSchema = genericDeclareNamedSchema (unPrefixSwagger "sdr_") data SearchPairedResults = SearchPairedResults { spr_results :: [FacetPaired Int UTCTime HyperdataDocument Int [Pair Int Text]] } deriving (Generic) $(deriveJSON (unPrefix "spr_") ''SearchPairedResults) instance Arbitrary SearchPairedResults where arbitrary = SearchPairedResults <$> arbitrary instance ToSchema SearchPairedResults where declareNamedSchema = genericDeclareNamedSchema (unPrefixSwagger "spr_") ----------------------------------------------------------------------- -- TODO-ACCESS: CanSearch? or is it part of CanGetNode -- TODO-EVENTS: No event, this is a read-only query. type SearchAPI results = Summary "Search endpoint" :> ReqBody '[JSON] SearchQuery :> QueryParam "offset" Int :> QueryParam "limit" Int :> QueryParam "order" OrderBy :> Post '[JSON] results type SearchDocsAPI = SearchAPI SearchDocResults searchDocs :: NodeId -> GargServer SearchDocsAPI searchDocs nId (SearchQuery q) o l order = SearchDocResults <$> searchInCorpus nId False q o l order --SearchResults <$> searchInCorpusWithContacts nId q o l order ----------------------------------------------------------------------- type SearchPairsAPI = Summary "" :> "list" :> Capture "list" ListId :> SearchAPI SearchPairedResults searchPairs :: NodeId -> GargServer SearchPairsAPI searchPairs pId lId (SearchQuery q) o l order = SearchPairedResults <$> searchInCorpusWithContacts pId lId q o l order -----------------------------------------------------------------------