mongoDB
je dostatečně obecný, aby fungoval v jakékoli monadě, která je instancí MonadBaseControl IO a MonadIO .
Můžete například zvolit IO monáda. V tomto případě potřebujete liftIO . runQuery uvnitř Scottyho akce:
import Web.Scotty
import Database.MongoDB
import qualified Data.Text.Lazy as T
import Control.Monad.IO.Class
runQuery :: Pipe -> Query -> IO [Document]
runQuery pipe query = access pipe master "nutrition" (find query >>= rest)
main = do
pipe <- connect $ host "127.0.0.1"
scotty 3000 $ do
get "/" $ do
res <- liftIO $ runQuery pipe (select [] "stock_foods")
text $ T.pack $ show res
Po @Sebastian Philipp
přidáno
MonadBaseControl instance pro Scotty.ActionT , není třeba nic zvedat. Můžete transparentně pracovat s mongoDB formulářem scotty. Stačí změnit typ podpisu a pustit liftIO s:
runQuery :: Pipe -> Query -> ActionM [Document]
...
get "/" $ do
res <- runQuery pipe (select [] "stock_foods")
text $ T.pack $ show res