{-# LANGUAGE OverloadedStrings #-} module ACMS.API.REST.Collection where #ifndef ghcjs_HOST_OS import Network.HTTP.Simple #else import ACMS.API.REST (setRequestMethod, setRequestBodyLBS, getResponseBody) import Data.ByteString.Char8 qualified as B import Data.Maybe import JavaScript.Web.XMLHttpRequest import Miso.String qualified as J #endif import ACMS.API.REST (APIMonad, fetch) import Data.Aeson qualified as A import Data.Function ((&)) import Data.String (fromString) import Miso.String (MisoString) import Text.Printf (printf) list :: (APIMonad m) => MisoString -> m [A.Object] list c = fromString (printf "http://localhost:8081/api/rest/collection/%s" c) & fetch >>= A.throwDecode read :: (APIMonad m) => MisoString -> MisoString -> m [A.Object] read c i = fromString (printf "http://localhost:8081/api/rest/collection/%s/%s" c i) & fetch >>= A.throwDecode update :: (APIMonad m) => MisoString -> MisoString -> A.Object -> m () update c i o = fromString (printf "http://localhost:8081/api/rest/collection/%s/%s" c i) & setRequestMethod "PUT" & setRequestBodyLBS (A.encode o) & fetch >>= A.throwDecode create :: (APIMonad m) => MisoString -> A.Object -> m A.Object create c o = do fromString (printf "http://localhost:8081/api/rest/collection/%s" c) & setRequestMethod "POST" & setRequestBodyLBS (A.encode o) & fetch >>= A.throwDecode delete :: (APIMonad m) => MisoString -> MisoString -> m [A.Object] delete c i = fromString (printf "http://localhost:8081/api/rest/collection/%s/%s" c i) & setRequestMethod "DELETE" & fetch >>= A.throwDecode schema :: (APIMonad m) => (A.FromJSON a) => MisoString -> m a schema c = fromString (printf "http://localhost:8081/api/rest/collection/%s/schema" c) & fetch >>= A.throwDecode