From dd5f67536ec199e93e06df479059261f0abdb026 Mon Sep 17 00:00:00 2001 From: qowevisa Date: Thu, 28 Nov 2024 15:01:16 +0200 Subject: [PATCH] Rename types.Payment to types.DbPayment and types.ItemBought to be types.DbItemBought sq --- handlers/payment.go | 31 ++++++++++++++++++++++++------- types/types.go | 20 ++++++++++---------- 2 files changed, 34 insertions(+), 17 deletions(-) diff --git a/handlers/payment.go b/handlers/payment.go index 91b8dd3..17e449d 100644 --- a/handlers/payment.go +++ b/handlers/payment.go @@ -9,16 +9,33 @@ import ( "github.com/gin-gonic/gin" ) -var itemBoughtTransform func(inp *db.ItemBought) types.ItemBought = func(inp *db.ItemBought) types.ItemBought { - return types.ItemBought{} +var itemBoughtTransform func(inp *db.ItemBought) types.DbItemBought = func(inp *db.ItemBought) types.DbItemBought { + var item types.DbItem + var price uint64 = 0 + if inp.Item != nil { + item = itemTransform(inp.Item) + price = inp.Item.Price + } + return types.DbItemBought{ + ID: inp.ID, + ItemID: inp.ItemID, + PaymentID: inp.PaymentID, + TypeID: inp.TypeID, + Price: price, + Quantity: inp.Quantity, + TotalCost: inp.TotalCost, + MetricType: inp.MetricType, + MetricValue: inp.MetricValue, + Item: item, + } } -var paymentTransform func(inp *db.Payment) types.Payment = func(inp *db.Payment) types.Payment { - var items []types.ItemBought +var paymentTransform func(inp *db.Payment) types.DbPayment = func(inp *db.Payment) types.DbPayment { + var items []types.DbItemBought for _, item := range inp.Items { items = append(items, itemBoughtTransform(&item)) } - return types.Payment{ + return types.DbPayment{ ID: inp.ID, CardID: inp.CardID, CategoryID: inp.CategoryID, @@ -36,7 +53,7 @@ var paymentTransform func(inp *db.Payment) types.Payment = func(inp *db.Payment) // @Accept json // @Produce json // @Param Authorization header string true "Bearer token" -// @Param payment body types.Payment true "Payment" +// @Param payment body types.DbPayment true "Payment" // @Success 200 {object} types.Message // @Failure 400 {object} types.ErrorResponse // @Failure 500 {object} types.ErrorResponse @@ -49,7 +66,7 @@ func PaymentAdd(c *gin.Context) { return } - var updates types.Payment + var updates types.DbPayment if err := c.ShouldBindJSON(&updates); err != nil { log.Printf("err is %v\n", err) c.JSON(400, types.ErrorResponse{Message: "Invalid request"}) diff --git a/types/types.go b/types/types.go index e0a4081..399740d 100644 --- a/types/types.go +++ b/types/types.go @@ -155,18 +155,18 @@ type DbCurrency struct { Symbol string `json:"symbol" example:"$"` } -type Payment struct { - ID uint `json:"id" example:"1"` - CardID uint `json:"card_id" example:"1"` - CategoryID uint `json:"category_id" example:"1"` - Title string `json:"title" example:"some title"` - Description string `json:"descr" example:"i bought some title for 20$"` - Note string `json:"note" example:"no i did not hit domain"` - Date time.Time `json:"date" example:"29/11/2001 12:00"` - Items []ItemBought `json:"items" example:"[]"` +type DbPayment struct { + ID uint `json:"id" example:"1"` + CardID uint `json:"card_id" example:"1"` + CategoryID uint `json:"category_id" example:"1"` + Title string `json:"title" example:"some title"` + Description string `json:"descr" example:"i bought some title for 20$"` + Note string `json:"note" example:"no i did not hit domain"` + Date time.Time `json:"date" example:"29/11/2001 12:00"` + Items []DbItemBought `json:"items" example:"[]"` } -type ItemBought struct { +type DbItemBought struct { ID uint `json:"id" example:"1"` NewName string `json:"new_name" example:"itemName"` NewComment string `json:"new_comment" example:"itemName"`