mirror of
https://github.com/FJurmanovic/wallet-go-api.git
synced 2026-02-06 06:08:16 +00:00
transaction edit
This commit is contained in:
@@ -19,8 +19,8 @@ func NewSubscriptionController(as *services.SubscriptionService, s *gin.RouterGr
|
|||||||
s.PUT("/end/:id", wc.End)
|
s.PUT("/end/:id", wc.End)
|
||||||
s.POST("", wc.New)
|
s.POST("", wc.New)
|
||||||
s.PUT("/:id", wc.Edit)
|
s.PUT("/:id", wc.Edit)
|
||||||
s.GET("", wc.GetAll)
|
|
||||||
s.GET("/:id", wc.Get)
|
s.GET("/:id", wc.Get)
|
||||||
|
s.GET("", wc.GetAll)
|
||||||
|
|
||||||
return wc
|
return wc
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -18,6 +18,8 @@ func NewTransactionController(as *services.TransactionService, s *gin.RouterGrou
|
|||||||
|
|
||||||
s.POST("", wc.New)
|
s.POST("", wc.New)
|
||||||
s.GET("", wc.GetAll)
|
s.GET("", wc.GetAll)
|
||||||
|
s.PUT("/:id", wc.Edit)
|
||||||
|
s.GET("/:id", wc.Get)
|
||||||
|
|
||||||
return wc
|
return wc
|
||||||
}
|
}
|
||||||
@@ -45,3 +47,33 @@ func (wc *TransactionController) GetAll(c *gin.Context) {
|
|||||||
|
|
||||||
c.JSON(200, fr)
|
c.JSON(200, fr)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (wc *TransactionController) Edit(c *gin.Context) {
|
||||||
|
body := new(models.TransactionEdit)
|
||||||
|
if err := c.ShouldBind(body); err != nil {
|
||||||
|
c.JSON(http.StatusBadRequest, gin.H{"error": err.Error()})
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
id := c.Param("id")
|
||||||
|
|
||||||
|
wm := wc.TransactionService.Edit(c, body, id)
|
||||||
|
c.JSON(200, wm)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (wc *TransactionController) Get(c *gin.Context) {
|
||||||
|
body := new(models.Auth)
|
||||||
|
params := new(models.Params)
|
||||||
|
|
||||||
|
auth := c.MustGet("auth")
|
||||||
|
body.Id = auth.(*models.Auth).Id
|
||||||
|
|
||||||
|
id := c.Param("id")
|
||||||
|
|
||||||
|
embed, _ := c.GetQuery("embed")
|
||||||
|
params.Embed = embed
|
||||||
|
|
||||||
|
fr := wc.TransactionService.Get(c, body, id, params)
|
||||||
|
|
||||||
|
c.JSON(200, fr)
|
||||||
|
}
|
||||||
|
|||||||
@@ -26,3 +26,12 @@ type NewTransactionBody struct {
|
|||||||
Description string `json:"description" form:"description"`
|
Description string `json:"description" form:"description"`
|
||||||
Amount json.Number `json:"amount" form:"amount"`
|
Amount json.Number `json:"amount" form:"amount"`
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type TransactionEdit struct {
|
||||||
|
Id string `json:"id" form:"id"`
|
||||||
|
WalletID string `json:"walletId" form:"walletId"`
|
||||||
|
TransactionTypeID string `json:"transactionTypeId" form:"transactionTypeId"`
|
||||||
|
TransactionDate time.Time `json:"transactionDate" form:"transactionDate"`
|
||||||
|
Description string `json:"description" form:"description"`
|
||||||
|
Amount json.Number `json:"amount" form:"amount"`
|
||||||
|
}
|
||||||
|
|||||||
@@ -5,6 +5,7 @@ import (
|
|||||||
"math"
|
"math"
|
||||||
"time"
|
"time"
|
||||||
"wallet-api/pkg/models"
|
"wallet-api/pkg/models"
|
||||||
|
"wallet-api/pkg/utl/common"
|
||||||
|
|
||||||
"github.com/go-pg/pg/v10"
|
"github.com/go-pg/pg/v10"
|
||||||
)
|
)
|
||||||
@@ -19,6 +20,9 @@ func (as *TransactionService) New(ctx context.Context, body *models.NewTransacti
|
|||||||
|
|
||||||
tm := new(models.Transaction)
|
tm := new(models.Transaction)
|
||||||
|
|
||||||
|
tx, _ := db.Begin()
|
||||||
|
defer tx.Rollback()
|
||||||
|
|
||||||
amount, _ := body.Amount.Float64()
|
amount, _ := body.Amount.Float64()
|
||||||
|
|
||||||
tm.Init()
|
tm.Init()
|
||||||
@@ -32,7 +36,8 @@ func (as *TransactionService) New(ctx context.Context, body *models.NewTransacti
|
|||||||
tm.TransactionDate = time.Now()
|
tm.TransactionDate = time.Now()
|
||||||
}
|
}
|
||||||
|
|
||||||
db.Model(tm).Insert()
|
tx.Model(tm).Insert()
|
||||||
|
tx.Commit()
|
||||||
|
|
||||||
return tm
|
return tm
|
||||||
}
|
}
|
||||||
@@ -67,3 +72,43 @@ func (as *TransactionService) GetAll(ctx context.Context, am *models.Auth, walle
|
|||||||
|
|
||||||
tx.Commit()
|
tx.Commit()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (as *TransactionService) Edit(ctx context.Context, body *models.TransactionEdit, id string) *models.Transaction {
|
||||||
|
db := as.Db.WithContext(ctx)
|
||||||
|
|
||||||
|
amount, _ := body.Amount.Float64()
|
||||||
|
|
||||||
|
tm := new(models.Transaction)
|
||||||
|
tm.Id = id
|
||||||
|
tm.Description = body.Description
|
||||||
|
tm.WalletID = body.WalletID
|
||||||
|
tm.TransactionTypeID = body.TransactionTypeID
|
||||||
|
tm.TransactionDate = body.TransactionDate
|
||||||
|
tm.Amount = float32(math.Round(amount*100) / 100)
|
||||||
|
|
||||||
|
tx, _ := db.Begin()
|
||||||
|
defer tx.Rollback()
|
||||||
|
|
||||||
|
tx.Model(tm).WherePK().UpdateNotZero()
|
||||||
|
|
||||||
|
tx.Commit()
|
||||||
|
|
||||||
|
return tm
|
||||||
|
}
|
||||||
|
|
||||||
|
func (as *TransactionService) Get(ctx context.Context, am *models.Auth, id string, params *models.Params) *models.Transaction {
|
||||||
|
db := as.Db.WithContext(ctx)
|
||||||
|
|
||||||
|
wm := new(models.Transaction)
|
||||||
|
wm.Id = id
|
||||||
|
|
||||||
|
tx, _ := db.Begin()
|
||||||
|
defer tx.Rollback()
|
||||||
|
|
||||||
|
qry := tx.Model(wm)
|
||||||
|
common.GenerateEmbed(qry, params.Embed).WherePK().Select()
|
||||||
|
|
||||||
|
tx.Commit()
|
||||||
|
|
||||||
|
return wm
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user