aboutsummaryrefslogtreecommitdiff
path: root/src/server/Main.hs
blob: 981c865f6d3d1f4d9813a50f6e225d9e5aaba5e5 (plain)
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
{-# LANGUAGE OverloadedStrings #-}

import Web.Scotty

import Network.Wai.Middleware.Static

import Data.Text (Text)

import Application

import Model.Database (runMigrations)

main :: IO ()
main = do
  runMigrations
  scotty 3000 $ do
    middleware $ staticPolicy (noDots >-> addBase "public")
    get "/" getIndexAction
    get "/users" getUsersAction
    get "/payments" getPaymentsAction
    post "/user/add" $ do
      email <- param "email" :: ActionM Text
      name <- param "name" :: ActionM Text
      addUserAction email name
    post "/user/delete" $ do
      email <- param "email" :: ActionM Text
      deleteUserAction email
    post "/payment/add" $ do
      email <- param "email" :: ActionM Text
      name <- param "name" :: ActionM Text
      cost <- param "cost" :: ActionM Int
      insertPaymentAction email name cost