-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathModels.hs
56 lines (47 loc) · 1.6 KB
/
Models.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
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
{-# OPTIONS_GHC -fno-warn-name-shadowing #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE TemplateHaskell #-}
{-# LANGUAGE DeriveDataTypeable #-}
{-# LANGUAGE TypeSynonymInstances #-}
{-# LANGUAGE FlexibleInstances #-}
{-# LANGUAGE MultiParamTypeClasses #-}
module Models ( User(..)
, insertUser, insertUser_
, updateUser, findUser ) where
import Data.Maybe
import Data.Bson
import Data.Typeable
import Database.MongoDB.Structured
import Database.MongoDB.Structured.Deriving.TH
import Control.Monad
import Control.Exception
-- | Perform action on DB. This is slow because it always tears down
-- the connection.
withDB :: Action IO b -> IO b
withDB act = do
pipe <- runIOE $ connect (host "localhost")
qr <- access pipe master "hails" act
close pipe
case qr of
Right r -> return r
Left e -> throwIO . userError $ "Failed with: " ++ show e
data User = User { userId :: SObjId
, userName :: String
, userEmail :: String
, userPassword :: String
} deriving (Eq, Show, Typeable)
$(deriveStructured ''User)
-- | Insert a user into database
insertUser :: User -> IO ObjectId
insertUser user = withDB $ liftM (unSObjId . fromJust . cast') $ insert user
-- | Insert a user into database
insertUser_ :: User -> IO ()
insertUser_ user = withDB $ insert_ user
-- | Save user into database
updateUser :: User -> IO ()
updateUser user = withDB $ save user
-- | Find existing user
findUser :: String -> IO (Maybe User)
findUser uName = withDB $ do
let query = select (UserName .== uName)
findOne query