forked from mattjbray/servant-elm-example-app
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathServer.hs
28 lines (24 loc) · 1010 Bytes
/
Server.hs
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
module Api.Server
( server
) where
import Control.Concurrent.STM (TVar, atomically, readTVar, writeTVar)
import Control.Monad.IO.Class (liftIO)
import qualified Data.Map.Strict as Map
import Data.UUID (toString)
import Servant ((:<|>) ((:<|>)), Server)
import System.Random (randomIO)
import Api.Types (Api, Book(bookId), BookDB)
server :: TVar BookDB -> Server Api
server tBookDb = listBooks :<|> createBook
where listBooks =
liftIO . atomically $ do
bookDb <- readTVar tBookDb
return (Map.elems bookDb)
createBook book = do
uuid <- liftIO randomIO
liftIO . atomically $ do
let idStr = toString uuid
bookWithId = book { bookId = Just (toString uuid) }
bookDb <- readTVar tBookDb
writeTVar tBookDb (Map.insert idStr bookWithId bookDb)
return bookWithId