Continue migration to echo

This commit is contained in:
2022-08-20 22:44:59 +00:00
parent 1a11555075
commit 9da4a6f03e
10 changed files with 76 additions and 99 deletions

View File

@ -9,109 +9,98 @@ import (
)
func (h *Handler) importYNAB(c echo.Context) error {
budgetID, succ := c.Params.Get("budgetid")
if !succ {
c.AbortWithStatusJSON(http.StatusBadRequest, ErrorResponse{"no budget_id specified"})
return
budgetID := c.Param("budgetid")
if budgetID == "" {
return echo.NewHTTPError(http.StatusBadRequest, "no budget_id specified")
}
budgetUUID, err := uuid.Parse(budgetID)
if !succ {
if err != nil {
return echo.NewHTTPError(http.StatusBadRequest, err)
return
}
ynab, err := postgres.NewYNABImport(c.Request().Context(), h.Service.Queries, budgetUUID)
if err != nil {
return echo.NewHTTPError(http.StatusInternalServerError, err)
return
return err
}
transactionsFile, err := c.FormFile("transactions")
if err != nil {
return echo.NewHTTPError(http.StatusInternalServerError, err)
return
return err
}
transactions, err := transactionsFile.Open()
if err != nil {
return echo.NewHTTPError(http.StatusInternalServerError, err)
return
return err
}
err = ynab.ImportTransactions(c.Request().Context(), transactions)
if err != nil {
return echo.NewHTTPError(http.StatusInternalServerError, err)
return
return err
}
assignmentsFile, err := c.FormFile("assignments")
if err != nil {
return echo.NewHTTPError(http.StatusInternalServerError, err)
return
return err
}
assignments, err := assignmentsFile.Open()
if err != nil {
return echo.NewHTTPError(http.StatusInternalServerError, err)
return
return err
}
err = ynab.ImportAssignments(c.Request().Context(), assignments)
if err != nil {
return echo.NewHTTPError(http.StatusInternalServerError, err)
return
return err
}
return nil
}
func (h *Handler) exportYNABTransactions(c echo.Context) error {
budgetID, succ := c.Params.Get("budgetid")
if !succ {
c.AbortWithStatusJSON(http.StatusBadRequest, ErrorResponse{"no budget_id specified"})
return
budgetID := c.Param("budgetid")
if budgetID == "" {
return echo.NewHTTPError(http.StatusBadRequest, "no budget_id specified")
}
budgetUUID, err := uuid.Parse(budgetID)
if !succ {
if err != nil {
return echo.NewHTTPError(http.StatusBadRequest, err)
return
}
ynab, err := postgres.NewYNABExport(c.Request().Context(), h.Service.Queries, budgetUUID)
if err != nil {
return echo.NewHTTPError(http.StatusInternalServerError, err)
return
return err
}
err = ynab.ExportTransactions(c.Request().Context(), c.Writer)
err = ynab.ExportTransactions(c.Request().Context(), c.Response().Writer)
if err != nil {
return echo.NewHTTPError(http.StatusInternalServerError, err)
return
return err
}
return nil
}
func (h *Handler) exportYNABAssignments(c echo.Context) error {
budgetID, succ := c.Params.Get("budgetid")
if !succ {
c.AbortWithStatusJSON(http.StatusBadRequest, ErrorResponse{"no budget_id specified"})
return
budgetID := c.Param("budgetid")
if budgetID == "" {
return echo.NewHTTPError(http.StatusBadRequest, "no budget_id specified")
}
budgetUUID, err := uuid.Parse(budgetID)
if !succ {
if err != nil {
return echo.NewHTTPError(http.StatusBadRequest, err)
return
}
ynab, err := postgres.NewYNABExport(c.Request().Context(), h.Service.Queries, budgetUUID)
if err != nil {
return echo.NewHTTPError(http.StatusInternalServerError, err)
return
}
err = ynab.ExportAssignments(c.Request().Context(), c.Writer)
err = ynab.ExportAssignments(c.Request().Context(), c.Response().Writer)
if err != nil {
return echo.NewHTTPError(http.StatusInternalServerError, err)
return
}
return nil
}