update ordedr list
This commit is contained in:
parent
b27e40b531
commit
d9b51a7616
@ -140,10 +140,7 @@ func (h *OrderHandler) ListOrders(c *gin.Context) {
|
|||||||
if modelReq.OutletID == nil && contextInfo.OutletID != uuid.Nil {
|
if modelReq.OutletID == nil && contextInfo.OutletID != uuid.Nil {
|
||||||
modelReq.OutletID = &contextInfo.OutletID
|
modelReq.OutletID = &contextInfo.OutletID
|
||||||
}
|
}
|
||||||
if modelReq.OutletID == nil {
|
|
||||||
util.HandleResponse(c.Writer, c.Request, contract.BuildErrorResponse([]*contract.ResponseError{contract.NewResponseError("validation_failed", "OrderHandler::ListOrders", "outlet_id is required")}), "OrderHandler::ListOrders")
|
|
||||||
return
|
|
||||||
}
|
|
||||||
response, err := h.orderService.ListOrders(c.Request.Context(), modelReq)
|
response, err := h.orderService.ListOrders(c.Request.Context(), modelReq)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
util.HandleResponse(c.Writer, c.Request, contract.BuildErrorResponse([]*contract.ResponseError{contract.NewResponseError("internal_error", "OrderHandler::ListOrders", err.Error())}), "OrderHandler::ListOrders")
|
util.HandleResponse(c.Writer, c.Request, contract.BuildErrorResponse([]*contract.ResponseError{contract.NewResponseError("internal_error", "OrderHandler::ListOrders", err.Error())}), "OrderHandler::ListOrders")
|
||||||
|
|||||||
@ -98,7 +98,42 @@ func (r *OrderRepositoryImpl) List(ctx context.Context, filters map[string]inter
|
|||||||
var orders []*entities.Order
|
var orders []*entities.Order
|
||||||
var total int64
|
var total int64
|
||||||
|
|
||||||
query := r.db.WithContext(ctx).Model(&entities.Order{}).
|
// organization_id is mandatory to prevent cross-org data leaks
|
||||||
|
organizationID, ok := filters["organization_id"]
|
||||||
|
if !ok {
|
||||||
|
return nil, 0, fmt.Errorf("organization_id is required for listing orders")
|
||||||
|
}
|
||||||
|
|
||||||
|
baseQuery := r.db.WithContext(ctx).Model(&entities.Order{}).
|
||||||
|
Where("organization_id = ?", organizationID)
|
||||||
|
|
||||||
|
// outlet_id is optional — if present, scope to that outlet; otherwise return all outlets in the org
|
||||||
|
if outletID, exists := filters["outlet_id"]; exists {
|
||||||
|
baseQuery = baseQuery.Where("outlet_id = ?", outletID)
|
||||||
|
}
|
||||||
|
|
||||||
|
for key, value := range filters {
|
||||||
|
switch key {
|
||||||
|
case "organization_id", "outlet_id":
|
||||||
|
// already handled above
|
||||||
|
case "search":
|
||||||
|
searchValue := "%" + value.(string) + "%"
|
||||||
|
baseQuery = baseQuery.Where("order_number ILIKE ?", searchValue)
|
||||||
|
case "date_from":
|
||||||
|
baseQuery = baseQuery.Where("created_at >= ?", value)
|
||||||
|
case "date_to":
|
||||||
|
baseQuery = baseQuery.Where("created_at <= ?", value)
|
||||||
|
default:
|
||||||
|
baseQuery = baseQuery.Where(key+" = ?", value)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Use separate queries for count and find to avoid GORM state mutation issues
|
||||||
|
if err := baseQuery.Count(&total).Error; err != nil {
|
||||||
|
return nil, 0, err
|
||||||
|
}
|
||||||
|
|
||||||
|
err := baseQuery.
|
||||||
Preload("Organization").
|
Preload("Organization").
|
||||||
Preload("Outlet").
|
Preload("Outlet").
|
||||||
Preload("User").
|
Preload("User").
|
||||||
@ -107,27 +142,8 @@ func (r *OrderRepositoryImpl) List(ctx context.Context, filters map[string]inter
|
|||||||
Preload("OrderItems.ProductVariant").
|
Preload("OrderItems.ProductVariant").
|
||||||
Preload("Payments").
|
Preload("Payments").
|
||||||
Preload("Payments.PaymentMethod").
|
Preload("Payments.PaymentMethod").
|
||||||
Preload("Payments.PaymentOrderItems")
|
Preload("Payments.PaymentOrderItems").
|
||||||
|
Limit(limit).Offset(offset).Order("created_at DESC").Find(&orders).Error
|
||||||
for key, value := range filters {
|
|
||||||
switch key {
|
|
||||||
case "search":
|
|
||||||
searchValue := "%" + value.(string) + "%"
|
|
||||||
query = query.Where("order_number ILIKE ?", searchValue)
|
|
||||||
case "date_from":
|
|
||||||
query = query.Where("created_at >= ?", value)
|
|
||||||
case "date_to":
|
|
||||||
query = query.Where("created_at <= ?", value)
|
|
||||||
default:
|
|
||||||
query = query.Where(key+" = ?", value)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if err := query.Count(&total).Error; err != nil {
|
|
||||||
return nil, 0, err
|
|
||||||
}
|
|
||||||
|
|
||||||
err := query.Limit(limit).Offset(offset).Order("created_at DESC").Find(&orders).Error
|
|
||||||
return orders, total, err
|
return orders, total, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user