module Server exposing ( signIn , createPayment , deletePayment , createIncome , deleteIncome , signOut ) import Task as Task exposing (Task) import Http import Date import Json.Decode exposing ((:=)) import Json.Encode as Json import Date exposing (Date) import Date.Extra.Format as DateFormat import Utils.Http exposing (..) import Model.Payment exposing (..) import Model.Income exposing (incomesDecoder, incomeIdDecoder, IncomeId) import Model.User exposing (Users, usersDecoder, UserId, userIdDecoder) import Model.Init exposing (Init) signIn : String -> Task Http.Error () signIn email = post ("/signIn?email=" ++ email) |> Task.map (always ()) createPayment : String -> Int -> Date -> Frequency -> Task Http.Error PaymentId createPayment name cost date frequency = Json.object [ ("name", Json.string name) , ("cost", Json.int cost) , ("date", Json.string (DateFormat.isoDateString date)) , ("frequency", Json.string (toString frequency)) ] |> Json.encode 0 |> Http.string |> postWithBody "/payment" |> flip Task.andThen (decodeHttpValue <| "id" := paymentIdDecoder) deletePayment : PaymentId -> Task Http.Error () deletePayment paymentId = delete ("/payment?id=" ++ (toString paymentId)) |> Task.map (always ()) createIncome : Int -> Date -> Task Http.Error IncomeId createIncome amount date = Json.object [ ("amount", Json.int amount) , ("date", Json.string (DateFormat.isoDateString date)) ] |> Json.encode 0 |> Http.string |> postWithBody "/income" |> flip Task.andThen (decodeHttpValue <| "id" := incomeIdDecoder) deleteIncome : IncomeId -> Task Http.Error () deleteIncome incomeId = delete ("/income?id=" ++ (toString incomeId)) |> Task.map (always ()) signOut : Task Http.Error () signOut = post "/signOut" |> Task.map (always ())