2023-10-08 15:59:42 +07:00
|
|
|
package orders
|
|
|
|
|
|
|
|
|
|
import (
|
|
|
|
|
"context"
|
|
|
|
|
"furtuna-be/internal/common/logger"
|
|
|
|
|
"furtuna-be/internal/entity"
|
|
|
|
|
"go.uber.org/zap"
|
|
|
|
|
"gorm.io/gorm"
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
type OrderRepository struct {
|
|
|
|
|
db *gorm.DB
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func NewOrderRepository(db *gorm.DB) *OrderRepository {
|
|
|
|
|
return &OrderRepository{
|
|
|
|
|
db: db,
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2024-06-04 02:59:31 +07:00
|
|
|
func (r *OrderRepository) Create(ctx context.Context, order *entity.Order) (*entity.Order, error) {
|
|
|
|
|
err := r.db.WithContext(ctx).Create(order).Error
|
|
|
|
|
if err != nil {
|
|
|
|
|
logger.ContextLogger(ctx).Error("error when creating order", zap.Error(err))
|
2023-10-08 15:59:42 +07:00
|
|
|
return nil, err
|
|
|
|
|
}
|
|
|
|
|
return order, nil
|
|
|
|
|
}
|
|
|
|
|
|
2024-06-04 02:59:31 +07:00
|
|
|
func (r *OrderRepository) UpdateStatus(ctx context.Context, orderID int64, status string) (*entity.Order, error) {
|
|
|
|
|
order := new(entity.Order)
|
|
|
|
|
if err := r.db.WithContext(ctx).First(order, orderID).Error; err != nil {
|
|
|
|
|
logger.ContextLogger(ctx).Error("error when finding order", zap.Error(err))
|
2023-10-08 15:59:42 +07:00
|
|
|
return nil, err
|
|
|
|
|
}
|
2024-06-04 02:59:31 +07:00
|
|
|
order.Status = status
|
|
|
|
|
if err := r.db.WithContext(ctx).Save(order).Error; err != nil {
|
|
|
|
|
logger.ContextLogger(ctx).Error("error when updating order status", zap.Error(err))
|
2023-10-08 15:59:42 +07:00
|
|
|
return nil, err
|
|
|
|
|
}
|
2024-06-04 02:59:31 +07:00
|
|
|
return order, nil
|
2023-10-08 15:59:42 +07:00
|
|
|
}
|
|
|
|
|
|
2024-06-04 02:59:31 +07:00
|
|
|
func (r *OrderRepository) FindByID(ctx context.Context, id int64) (*entity.Order, error) {
|
|
|
|
|
var order entity.Order
|
|
|
|
|
if err := r.db.WithContext(ctx).Preload("OrderItems").First(&order, id).Error; err != nil {
|
|
|
|
|
logger.ContextLogger(ctx).Error("error when finding order by ID", zap.Error(err))
|
|
|
|
|
return nil, err
|
2023-10-08 15:59:42 +07:00
|
|
|
}
|
2024-06-04 02:59:31 +07:00
|
|
|
return &order, nil
|
2023-10-08 15:59:42 +07:00
|
|
|
}
|
|
|
|
|
|
2024-06-04 02:59:31 +07:00
|
|
|
func (r *OrderRepository) Update(ctx context.Context, order *entity.Order) (*entity.Order, error) {
|
|
|
|
|
if err := r.db.WithContext(ctx).Save(order).Error; err != nil {
|
|
|
|
|
logger.ContextLogger(ctx).Error("error when updating order", zap.Error(err))
|
2023-10-08 15:59:42 +07:00
|
|
|
return nil, err
|
|
|
|
|
}
|
2024-06-04 02:59:31 +07:00
|
|
|
return order, nil
|
2023-10-08 15:59:42 +07:00
|
|
|
}
|