import Control.Applicative (liftA3) import Control.Monad.IO.Class (liftIO) import qualified Data.Text.Lazy as LT import Network.Wai.Middleware.Gzip (GzipFiles (GzipCompress)) import qualified Network.Wai.Middleware.Gzip as W import Network.Wai.Middleware.Static import Web.Scotty import Common.Model (Frequency (..), Payment (..)) import qualified Conf import qualified Controller.Category as Category import qualified Controller.Income as Income import qualified Controller.Index as Index import qualified Controller.Payment as Payment import qualified Controller.SignIn as SignIn import qualified Data.Time as Time import Job.Daemon (runDaemons) import qualified Model.Income as IncomeM import Model.Payer (getOrderedExceedingPayers) import qualified Model.Payment as PaymentM import qualified Model.Query as Query import qualified Model.User as UserM main :: IO () main = do conf <- Conf.get "application.conf" _ <- runDaemons conf scotty (Conf.port conf) $ do middleware $ W.gzip $ W.def { W.gzipFiles = GzipCompress } middleware . staticPolicy $ noDots >-> addBase "public" get "/exceedingPayer" $ do time <- liftIO Time.getCurrentTime (users, incomes, payments) <- liftIO . Query.run $ liftA3 (,,) UserM.list IncomeM.list PaymentM.list let punctualPayments = filter ((==) Punctual . _payment_frequency) payments exceedingPayers = getOrderedExceedingPayers time users incomes punctualPayments text . LT.pack . show $ exceedingPayers get "/" $ do signInToken <- mbParam "signInToken" Index.get conf signInToken post "/signIn" $ do jsonData >>= SignIn.signIn conf post "/signOut" $ Index.signOut conf post "/payment" $ jsonData >>= Payment.create put "/payment" $ jsonData >>= Payment.editOwn delete "/payment" $ do paymentId <- param "id" Payment.deleteOwn paymentId post "/income" $ jsonData >>= Income.create put "/income" $ jsonData >>= Income.editOwn delete "/income" $ do incomeId <- param "id" Income.deleteOwn incomeId post "/category" $ jsonData >>= Category.create put "/category" $ jsonData >>= Category.edit delete "/category" $ do categoryId <- param "id" Category.delete categoryId mbParam :: Parsable a => LT.Text -> ActionM (Maybe a) mbParam key = (Just <$> param key) `rescue` (const . return $ Nothing)