Add bulk creation of expencies

This commit is contained in:
qowevisa 2024-11-27 07:39:23 +02:00
parent 4d452737cd
commit 3e8f56eb0a
4 changed files with 159 additions and 0 deletions

View File

@ -99,6 +99,7 @@ func main() {
expensesRoutes := api.Group("/expense", middleware.AuthMiddleware()) expensesRoutes := api.Group("/expense", middleware.AuthMiddleware())
{ {
expensesRoutes.POST("/add", handlers.ExpenseAdd) expensesRoutes.POST("/add", handlers.ExpenseAdd)
expensesRoutes.POST("/bulk_create", handlers.ExpenseBulkCreate)
expensesRoutes.GET("/:id", handlers.ExpenseGetId) expensesRoutes.GET("/:id", handlers.ExpenseGetId)
expensesRoutes.GET("/all", handlers.ExpenseGetAll) expensesRoutes.GET("/all", handlers.ExpenseGetAll)
expensesRoutes.PUT("/edit/:id", handlers.ExpensePutId) expensesRoutes.PUT("/edit/:id", handlers.ExpensePutId)

View File

@ -20,6 +20,66 @@ type Expense struct {
Type *Type Type *Type
} }
type Helper_ExpenseBulk struct {
PropagateCardID bool
CardID uint
PropagateTypeID bool
TypeID uint
PropagateValue bool
Value uint64
PropagateComment bool
Comment string
PropagateDate bool
Date time.Time
UserID uint
}
func (he *Helper_ExpenseBulk) CreateExpenseFromChild(c Expense) *Expense {
var cardID uint
var typeID uint
var value uint64
var comment string
var date time.Time
if he.PropagateCardID {
cardID = he.CardID
} else {
cardID = c.CardID
}
if he.PropagateTypeID {
typeID = he.TypeID
} else {
typeID = c.TypeID
}
if he.PropagateValue {
value = he.Value
} else {
value = c.Value
}
if he.PropagateComment {
comment = he.Comment
} else {
comment = c.Comment
}
if he.PropagateValue {
value = he.Value
} else {
value = c.Value
}
if he.PropagateDate {
date = he.Date
} else {
date = c.Date
}
return &Expense{
CardID: cardID,
TypeID: typeID,
Value: value,
Comment: comment,
Date: date,
UserID: he.UserID,
}
}
// Implements db.UserIdentifiable:1 // Implements db.UserIdentifiable:1
func (e Expense) GetID() uint { func (e Expense) GetID() uint {
return e.ID return e.ID

View File

@ -2,6 +2,7 @@ package handlers
import ( import (
"fmt" "fmt"
"log"
"git.qowevisa.me/Qowevisa/fin-check-api/db" "git.qowevisa.me/Qowevisa/fin-check-api/db"
"git.qowevisa.me/Qowevisa/fin-check-api/types" "git.qowevisa.me/Qowevisa/fin-check-api/types"
@ -103,6 +104,85 @@ func ExpenseAdd(c *gin.Context) {
})(c) })(c)
} }
// @Summary Add many expenses
// @Description Add expense by propagating main struct to every child in children field
// @Tags expense
// @Accept json
// @Produce json
// @Param Authorization header string true "Bearer token"
// @Param expense body types.DbExpenseBulk true "Expense"
// @Success 200 {object} types.Message
// @Failure 400 {object} types.ErrorResponse
// @Failure 500 {object} types.ErrorResponse
// @Security ApiKeyAuth
// @Router /expense/add [post]
func ExpenseBulkCreate(c *gin.Context) {
userID, err := GetUserID(c)
if err != nil {
c.JSON(500, types.ErrorResponse{Message: err.Error()})
return
}
var u types.DbExpenseBulk
if err := c.ShouldBindJSON(&u); err != nil {
log.Printf("err is %v\n", err)
c.JSON(400, types.ErrorResponse{Message: "Invalid request"})
return
}
if u.IsEveryFieldPropagated() {
c.JSON(400, types.ErrorResponse{Message: "You can't just try to propagate every field for children."})
return
}
he := &db.Helper_ExpenseBulk{
PropagateCardID: u.PropagateCardID,
CardID: u.CardID,
PropagateTypeID: u.PropagateTypeID,
TypeID: u.TypeID,
PropagateValue: u.PropagateValue,
Value: u.Value,
PropagateComment: u.PropagateComment,
Comment: u.Comment,
PropagateDate: u.PropagateDate,
Date: u.Date,
UserID: userID,
}
var expenses []*db.Expense
for _, child := range u.Children {
c := db.Expense{
CardID: child.CardID,
TypeID: child.TypeID,
Value: child.Value,
Comment: child.Comment,
Date: child.Date,
}
expenses = append(expenses, he.CreateExpenseFromChild(c))
}
dbc := db.Connect()
var whatToRollback []*db.Expense
shouldRollback := false
defer func() {
if shouldRollback {
for _, e := range whatToRollback {
if err := dbc.Delete(e).Error; err != nil {
log.Printf("dbc.Delete ERROR: %v\n", err)
}
}
}
}()
for _, entity := range expenses {
if err := dbc.Create(entity).Error; err != nil {
shouldRollback = true
c.JSON(500, types.ErrorResponse{Message: err.Error()})
return
}
whatToRollback = append(whatToRollback, entity)
}
c.JSON(200, types.Message{Info: fmt.Sprintf("%d entities were created successfully!", len(expenses))})
}
// @Summary Edit expense by id // @Summary Edit expense by id
// @Description Edit expense by id // @Description Edit expense by id
// @Tags expense // @Tags expense

View File

@ -87,6 +87,24 @@ type DbExpense struct {
ShowValue string `json:"show_value" example:"10.35$"` ShowValue string `json:"show_value" example:"10.35$"`
} }
type DbExpenseBulk struct {
PropagateCardID bool `json:"propagate_card_id" example:"false"`
CardID uint `json:"card_id" example:"1"`
PropagateTypeID bool `json:"propagate_type_id" example:"false"`
TypeID uint `json:"type_id" example:"1"`
PropagateValue bool `json:"propagate_value" example:"false"`
Value uint64 `json:"value" example:"1025"`
PropagateComment bool `json:"propagate_comment" example:"false"`
Comment string `json:"comment" example:"some comment"`
PropagateDate bool `json:"propagate_date" example:"false"`
Date time.Time `json:"date" example:"29/11/2001 12:00"`
Children []DbExpense `json:"children"`
}
func (e DbExpenseBulk) IsEveryFieldPropagated() bool {
return e.PropagateCardID && e.PropagateTypeID && e.PropagateValue && e.PropagateComment && e.PropagateDate
}
type DbTransfer struct { type DbTransfer struct {
ID uint `json:"id" example:"1"` ID uint `json:"id" example:"1"`
FromCardID uint `json:"from_card_id" example:"1"` FromCardID uint `json:"from_card_id" example:"1"`