mirror of
https://gitlab.com/mbugroup/lti-api.git
synced 2026-05-20 13:31:56 +00:00
feat(BE): fixing fifo system recording
This commit is contained in:
@@ -192,6 +192,16 @@ func (s *fifoService) Consume(ctx context.Context, req StockConsumeRequest) (*St
|
||||
if req.Quantity < 0 {
|
||||
return nil, errors.New("quantity must be zero or greater")
|
||||
}
|
||||
if s.logger.IsLevelEnabled(logrus.DebugLevel) {
|
||||
s.logger.WithFields(logrus.Fields{
|
||||
"usable_key": req.UsableKey.String(),
|
||||
"usable_id": req.UsableID,
|
||||
"requested_quantity": req.Quantity,
|
||||
"allow_pending": req.AllowPending,
|
||||
"product_warehouse_id": req.ProductWarehouseID,
|
||||
}).Debug("fifo consume request")
|
||||
}
|
||||
|
||||
|
||||
cfg, ok := fifo.Usable(req.UsableKey)
|
||||
if !ok {
|
||||
@@ -220,6 +230,19 @@ func (s *fifoService) Consume(ctx context.Context, req StockConsumeRequest) (*St
|
||||
currentPending := ctxRow.PendingQty
|
||||
currentTotal := currentUsage + currentPending
|
||||
delta := req.Quantity - currentTotal
|
||||
if s.logger.IsLevelEnabled(logrus.DebugLevel) {
|
||||
s.logger.WithFields(logrus.Fields{
|
||||
"usable_key": req.UsableKey.String(),
|
||||
"usable_id": req.UsableID,
|
||||
"product_warehouse_id": productWarehouseID,
|
||||
"current_usage_qty": currentUsage,
|
||||
"current_pending_qty": currentPending,
|
||||
"current_total_qty": currentTotal,
|
||||
"requested_quantity": req.Quantity,
|
||||
"calculated_delta": delta,
|
||||
"input_warehouse_match": req.ProductWarehouseID == 0 || req.ProductWarehouseID == productWarehouseID,
|
||||
}).Debug("fifo consume context")
|
||||
}
|
||||
|
||||
var (
|
||||
usageDelta float64
|
||||
@@ -285,6 +308,20 @@ func (s *fifoService) Consume(ctx context.Context, req StockConsumeRequest) (*St
|
||||
result.ReleasedQuantity = releasedAmount
|
||||
result.UsageQuantity = currentUsage + usageDelta
|
||||
result.PendingQuantity = currentPending + pendingDelta
|
||||
if s.logger.IsLevelEnabled(logrus.DebugLevel) {
|
||||
s.logger.WithFields(logrus.Fields{
|
||||
"usable_key": req.UsableKey.String(),
|
||||
"usable_id": req.UsableID,
|
||||
"product_warehouse_id": productWarehouseID,
|
||||
"usage_delta": usageDelta,
|
||||
"pending_delta": pendingDelta,
|
||||
"released_quantity": releasedAmount,
|
||||
"added_allocations": len(addedAlloc),
|
||||
"final_usage_qty": result.UsageQuantity,
|
||||
"final_pending_qty": result.PendingQuantity,
|
||||
"final_requested_qty": result.RequestedQuantity,
|
||||
}).Debug("fifo consume result")
|
||||
}
|
||||
|
||||
return nil
|
||||
})
|
||||
@@ -299,6 +336,13 @@ func (s *fifoService) ReleaseUsage(ctx context.Context, req StockReleaseRequest)
|
||||
if req.UsableID == 0 || strings.TrimSpace(req.UsableKey.String()) == "" {
|
||||
return errors.New("usable key and id are required")
|
||||
}
|
||||
if s.logger.IsLevelEnabled(logrus.DebugLevel) {
|
||||
s.logger.WithFields(logrus.Fields{
|
||||
"usable_key": req.UsableKey.String(),
|
||||
"usable_id": req.UsableID,
|
||||
"reason": req.Reason,
|
||||
}).Debug("fifo release request")
|
||||
}
|
||||
|
||||
return s.withTransaction(ctx, req.Tx, func(tx *gorm.DB) error {
|
||||
cfg, ok := fifo.Usable(req.UsableKey)
|
||||
@@ -310,6 +354,16 @@ func (s *fifoService) ReleaseUsage(ctx context.Context, req StockReleaseRequest)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
if s.logger.IsLevelEnabled(logrus.DebugLevel) {
|
||||
s.logger.WithFields(logrus.Fields{
|
||||
"usable_key": req.UsableKey.String(),
|
||||
"usable_id": req.UsableID,
|
||||
"product_warehouse_id": ctxRow.ProductWarehouseID,
|
||||
"current_usage_qty": ctxRow.UsageQty,
|
||||
"current_pending_qty": ctxRow.PendingQty,
|
||||
"current_total_qty": ctxRow.UsageQty + ctxRow.PendingQty,
|
||||
}).Debug("fifo release context")
|
||||
}
|
||||
|
||||
var usageDelta, pendingDelta float64
|
||||
if ctxRow.UsageQty > 0 {
|
||||
@@ -326,6 +380,15 @@ func (s *fifoService) ReleaseUsage(ctx context.Context, req StockReleaseRequest)
|
||||
return err
|
||||
}
|
||||
|
||||
if s.logger.IsLevelEnabled(logrus.DebugLevel) {
|
||||
s.logger.WithFields(logrus.Fields{
|
||||
"usable_key": req.UsableKey.String(),
|
||||
"usable_id": req.UsableID,
|
||||
"usage_delta": usageDelta,
|
||||
"pending_delta": pendingDelta,
|
||||
}).Debug("fifo release applied")
|
||||
}
|
||||
|
||||
return s.allocations.ReleaseByUsable(ctx, req.UsableKey.String(), req.UsableID, req.Reason, func(db *gorm.DB) *gorm.DB {
|
||||
return s.txOrDB(tx, db)
|
||||
})
|
||||
|
||||
Reference in New Issue
Block a user