Add ACMS.API.REST.Collection

This commit is contained in:
Alexander Foremny
2024-10-11 15:01:17 +02:00
parent 35bf45a81d
commit 9a44128f4c
2 changed files with 93 additions and 0 deletions

View File

@@ -7,6 +7,43 @@ maintainer: aforemny@posteo.de
author: Alexander Foremny
build-type: Simple
library
exposed-modules: ACMS.API.REST.Collection
hs-source-dirs: lib
default-language: GHC2021
default-extensions:
BlockArguments LambdaCase OverloadedStrings ViewPatterns
OverloadedRecordDot NoFieldSelectors MultiWayIf
ghc-options: -Wall -threaded
build-depends:
aeson,
astore,
attoparsec,
autotypes,
base,
bytestring,
common,
containers,
directory,
filepath,
gitlib,
gitlib-libgit2,
hinotify,
hlibgit2,
http-conduit,
http-types,
mtl,
optparse-applicative,
safe,
split,
stm,
tagged,
text,
utf8-string,
wai,
warp
executable backend
main-is: Main.hs
hs-source-dirs: app

View File

@@ -0,0 +1,56 @@
{-# LANGUAGE OverloadedStrings #-}
module ACMS.API.REST.Collection where
import Data.Aeson qualified as A
import Data.Aeson.KeyMap qualified as AM
import Data.ByteString.Lazy.UTF8 qualified as LB
import Data.Function ((&))
import Data.Text qualified as T
import Network.HTTP.Simple
import Text.Printf (printf)
type CollectionName = T.Text
list :: T.Text -> IO [A.Object]
list c =
"http://localhost:8081"
& setRequestMethod "POST"
& setRequestBodyLBS (LB.fromString (printf "SELECT %s FROM %s" c c))
& httpLBS
>>= A.throwDecode . getResponseBody
read :: T.Text -> T.Text -> IO [A.Object]
read c i =
"http://localhost:8081"
& setRequestMethod "POST"
& setRequestBodyLBS
(LB.fromString (printf "SELECT %s FROM %s WHERE %s.$fileName == \"%s\"" c c c i))
& httpLBS
>>= A.throwDecode . getResponseBody
update :: T.Text -> T.Text -> A.Object -> IO ()
update c i o =
"http://localhost:8081"
& setRequestMethod "POST"
& setRequestBodyLBS
(LB.fromString (printf "UPDATE %s SET %s WHERE %s.$fileName == \"%s\"" c (LB.toString (A.encode o)) c i))
& httpLBS
>>= A.throwDecode . getResponseBody
create :: T.Text -> T.Text -> A.Object -> IO ()
create c i o =
"http://localhost:8081"
& setRequestMethod "POST"
& setRequestBodyLBS
(LB.fromString (printf "INSERT %s INTO %s" (LB.toString (A.encode (AM.insert "$fileName" (A.String i) o))) c))
& httpLBS
>>= A.throwDecode . getResponseBody
delete :: T.Text -> T.Text -> IO [A.Object]
delete c i =
"http://localhost:8081"
& setRequestMethod "POST"
& setRequestBodyLBS
(LB.fromString (printf "DELETE FROM %s WHERE %s.$fileName == \"%s\"" c c i))
& httpLBS
>>= A.throwDecode . getResponseBody