diff options
Diffstat (limited to 'src/server/Controller/Income.hs')
-rw-r--r-- | src/server/Controller/Income.hs | 28 |
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 ) |