Fix haddock parse error
[gargantext.git] / src / Gargantext / API / Swagger.hs
index 26e0c53bd58c253444a3016345a89bd7d2b196f0..bd79282262e2b9feaf033139865f876daa512603 100644 (file)
+{-# OPTIONS_GHC -freduction-depth=400 #-}
+
 {-|
 Module      : Gargantext.API.Swagger
-Description : Swagger Documentation API
+Description : Swagger API generation
 Copyright   : (c) CNRS, 2017-Present
 License     : AGPL + CECILL v3
 Maintainer  : team@gargantext.org
 Stability   : experimental
 Portability : POSIX
--}
-
-{-# OPTIONS_GHC -fno-warn-name-shadowing #-}
-
-{-# LANGUAGE DataKinds                   #-}
-{-# LANGUAGE DeriveGeneric               #-}
-{-# LANGUAGE FlexibleInstances           #-}
-{-# LANGUAGE OverloadedStrings           #-}
-{-# LANGUAGE TemplateHaskell             #-}
-{-# LANGUAGE TypeOperators               #-}
-{-# LANGUAGE KindSignatures              #-}
-{-# LANGUAGE TypeFamilies                #-}
-{-# LANGUAGE UndecidableInstances        #-}
-
----------------------------------------------------------------------
-module Gargantext.API.Swagger
-      where
----------------------------------------------------------------------
-import           Gargantext.Prelude
-
-import           System.IO (FilePath, print)
-
-import           GHC.Generics (D1, Meta (..), Rep)
-import           GHC.TypeLits (AppendSymbol, Symbol)
-
-import           Control.Lens
-import           Data.Aeson.Encode.Pretty (encodePretty)
-import qualified Data.ByteString.Lazy.Char8 as BL8
-import           Data.Swagger
-import           Data.Text (Text, pack)
---import qualified Data.Set as Set
-
-import           Database.PostgreSQL.Simple (Connection, connect)
-
-import           Network.Wai
-import           Network.Wai.Handler.Warp
-
-import           Servant
-import           Servant.Mock (mock)
-import           Servant.Swagger
-import           Servant.Swagger.UI
-import           Servant.Static.TH (createApiAndServerDecs)
--- import Servant.API.Stream
-
-import Gargantext.API.Node ( Roots    , roots
-                           , NodeAPI  , nodeAPI
-                           , NodesAPI , nodesAPI
-                           )
-import Gargantext.API.Count ( CountAPI, count, Query)
-import Gargantext.Database.Utils (databaseParameters)
-
----------------------------------------------------------------------
----------------------------------------------------------------------
-type PortNumber = Int
----------------------------------------------------------------------
--- | API Global
-
-
--- | API for serving @swagger.json@
--- TODO Do we need to add this in the API ?
--- type SwaggerAPI = "swagger.json" :> Get '[JSON] Swagger
-
-type SwaggerAPI = SwaggerSchemaUI "swagger-ui" "swagger.json"
-
 
--- | Serve front end files
-$(createApiAndServerDecs "FrontEndAPI" "frontEndServer" "frontEnd")
-
-type SwaggerFrontAPI = SwaggerAPI :<|> FrontEndAPI 
-
-type API = SwaggerFrontAPI :<|> GargAPI
-
----------------------------------------------------------------------
--- | Server declaration
-server :: Connection -> Server API
-server conn = swaggerFront
-          :<|> roots    conn
-          :<|> nodeAPI  conn
-          :<|> nodeAPI  conn
-          :<|> nodesAPI conn
-          :<|> count
-
----------------------------------------------------------------------
-swaggerFront :: Server SwaggerFrontAPI
-swaggerFront = schemaUiServer swaggerDoc
-           :<|> frontEndServer
-
-gargMock :: Server GargAPI
-gargMock = mock apiGarg Proxy
-
----------------------------------------------------------------------
-app :: Connection -> Application
-app  = serve api . server
-
-appMock :: Application
-appMock = serve api (swaggerFront :<|> gargMock)
+-}
 
 ---------------------------------------------------------------------
-api :: Proxy API
-api  = Proxy
-
-apiGarg :: Proxy GargAPI
-apiGarg  = Proxy
+module Gargantext.API.Swagger where
 ---------------------------------------------------------------------
+import Control.Lens
+import Data.Swagger
+import Data.Version (showVersion)
+import Servant
+import Servant.Swagger
+import qualified Paths_gargantext as PG -- cabal magic build module
 
-schemaUiServer :: (Server api ~ Handler Swagger)
-        => Swagger -> Server (SwaggerSchemaUI' dir api)
-schemaUiServer = swaggerSchemaUIServer
-
-
--- Type Familiy for the Documentation
-type family TypeName (x :: *) :: Symbol where
-    TypeName Int  = "Int"
-    TypeName Text = "Text"
-    TypeName x    = GenericTypeName x (Rep x ())
-
-type family GenericTypeName t (r :: *) :: Symbol where
-    GenericTypeName t (D1 ('MetaData name mod pkg nt) f x) = name
-
-type Desc t n = Description (AppendSymbol (TypeName t) (AppendSymbol " | " n))
-
+import Gargantext.API.Routes
+import Gargantext.Prelude
 
 -- | Swagger Specifications
 swaggerDoc :: Swagger
 swaggerDoc = toSwagger (Proxy :: Proxy GargAPI)
-  & info.title       .~ "Gargantext"
-  & info.version     .~ "0.1.0"
+  & info.title       .~ "GarganText"
+  & info.version     .~ (cs $ showVersion PG.version)
   -- & info.base_url     ?~ (URL "http://gargantext.org/")
   & info.description ?~ "REST API specifications"
   -- & tags             .~ Set.fromList [Tag "Garg" (Just "Main perations") Nothing]
   & applyTagsFor (subOperations (Proxy :: Proxy GargAPI)(Proxy :: Proxy GargAPI)) 
-                 ["Garg" & description ?~ "Main operations"]
+                 ["Gargantext" & description ?~ "Main operations"]
   & info.license     ?~ ("AGPLV3 (English) and CECILL (French)" & url ?~ URL urlLicence )
     where
         urlLicence = "https://gitlab.iscpif.fr/gargantext/haskell-gargantext/blob/master/LICENSE"
-
--- | Output generated @swagger.json@ file for the @'TodoAPI'@.
-swaggerWriteJSON :: IO ()
-swaggerWriteJSON = BL8.writeFile "swagger.json" (encodePretty swaggerDoc)
-
-
--- | startGargantext takes as parameters port number and Ini file.
-startGargantext :: PortNumber -> FilePath -> IO ()
-startGargantext port file = do
-  print ("Starting Gargantext server" <> show port)
-  print ("http://localhost:" <> show port)
-  param <- databaseParameters file
-  conn  <- connect param
-  run port (app conn)
-
-startGargantextMock :: PortNumber -> IO ()
-startGargantextMock port = do
-  print (pack "Starting Mock server")
-  print (pack $ "curl "
-        <> "-H \"content-type: application/json"
-        <> "-d \'{\"query_query\":\"query\"}\'  "
-        <> "-v  http://localhost:" 
-        <> show port 
-        <>"/count"
-         )
-  run port appMock
-