diff options
Diffstat (limited to 'src/server/Main.hs')
-rw-r--r-- | src/server/Main.hs | 59 |
1 files changed, 34 insertions, 25 deletions
diff --git a/src/server/Main.hs b/src/server/Main.hs index 4f74f8e..e4ad9f6 100644 --- a/src/server/Main.hs +++ b/src/server/Main.hs @@ -20,6 +20,7 @@ import Controller.Income import Model.Database (runMigrations) import Model.Frequency +import Conf (Conf) import qualified Conf main :: IO () @@ -35,7 +36,9 @@ main = do middleware $ staticPolicy (noDots >-> addBase "public") - get "/" $ + api conf + + notFound $ ( do signInToken <- param "signInToken" :: ActionM Text successOrError <- validateSignIn conf signInToken @@ -46,37 +49,43 @@ main = do (getIndex conf Nothing) ) `rescue` (\_ -> getIndex conf Nothing) - post "/signOut" signOut - -- SignIn +api :: Conf -> ScottyM () +api conf = do + -- Sign + + post "/api/signIn" $ do + email <- param "email" :: ActionM Text + signIn conf email + + post "/api/signOut" signOut + + -- Users - post "/signIn" $ do - email <- param "email" :: ActionM Text - signIn conf email + get "/api/users" getUsers + get "/api/whoAmI" whoAmI - -- Users + -- Incomes - get "/users" getUsers - get "/whoAmI" whoAmI - get "/incomes" getIncomes - post "/income" $ do - amount <- param "amount" :: ActionM Int - setIncome amount + get "/api/incomes" getIncomes + post "/api/income" $ do + amount <- param "amount" :: ActionM Int + setIncome amount - -- Payments + -- Payments - get "/payments" getPayments + get "/api/payments" getPayments - get "/monthlyPayments" getMonthlyPayments + get "/api/monthlyPayments" getMonthlyPayments - post "/payment/add" $ do - name <- param "name" :: ActionM Text - cost <- param "cost" :: ActionM Text - frequency <- param "frequency" :: ActionM Frequency - createPayment name cost frequency + post "/api/payment/add" $ do + name <- param "name" :: ActionM Text + cost <- param "cost" :: ActionM Text + frequency <- param "frequency" :: ActionM Frequency + createPayment name cost frequency - post "/payment/delete" $ do - paymentId <- param "id" :: ActionM Text - deletePayment paymentId + post "/api/payment/delete" $ do + paymentId <- param "id" :: ActionM Text + deletePayment paymentId - get "/payments/count" getPaymentsCount + get "/api/payments/count" getPaymentsCount |