aboutsummaryrefslogtreecommitdiff
path: root/src/server/Controller/Income.hs
diff options
context:
space:
mode:
Diffstat (limited to 'src/server/Controller/Income.hs')
-rw-r--r--src/server/Controller/Income.hs28
1 files changed, 24 insertions, 4 deletions
diff --git a/src/server/Controller/Income.hs b/src/server/Controller/Income.hs
index 51861d3..4474d51 100644
--- a/src/server/Controller/Income.hs
+++ b/src/server/Controller/Income.hs
@@ -2,21 +2,29 @@
module Controller.Income
( getIncomes
- , setIncome
+ , addIncome
+ , deleteOwnIncome
) where
import Web.Scotty
+import Network.HTTP.Types.Status (ok200, badRequest400)
+
import Control.Monad.IO.Class (liftIO)
import Database.Persist
+import Data.Text (Text)
+import qualified Data.Text.Lazy as TL
+import Data.Time.Clock (UTCTime)
+
import qualified Secure
import Json (jsonId)
import Model.Database
import qualified Model.Income as Income
+import qualified Model.Message.Key as Key
getIncomes :: ActionM ()
getIncomes =
@@ -24,8 +32,20 @@ getIncomes =
(liftIO $ map Income.getJsonIncome <$> runDb Income.getIncomes) >>= json
)
-setIncome :: Int -> ActionM ()
-setIncome amount =
+addIncome :: UTCTime -> Int -> ActionM ()
+addIncome creation amount =
+ Secure.loggedAction (\user ->
+ (liftIO . runDb $ Income.addIncome (entityKey user) creation amount) >>= jsonId
+ )
+
+deleteOwnIncome :: Text -> ActionM ()
+deleteOwnIncome incomeId =
Secure.loggedAction (\user -> do
- (liftIO . runDb $ Income.setIncome (entityKey user) amount) >>= jsonId
+ deleted <- liftIO . runDb $ Income.deleteOwnIncome user (textToKey incomeId)
+ if deleted
+ then
+ status ok200
+ else do
+ status badRequest400
+ text . TL.pack . show $ Key.IncomeNotDeleted
)