MIF_E31222379_BE/internal/repositories/requestpickup_repo.go

182 lines
6.6 KiB
Go

package repositories
import (
"fmt"
"rijig/model"
"gorm.io/gorm"
)
type RequestPickupRepository interface {
CreateRequestPickup(request *model.RequestPickup) error
CreateRequestPickupItem(item *model.RequestPickupItem) error
FindRequestPickupByID(id string) (*model.RequestPickup, error)
FindAllRequestPickups(userId string) ([]model.RequestPickup, error)
FindAllAutomaticMethodRequest(requestMethod, statuspickup string) ([]model.RequestPickup, error)
FindRequestPickupByAddressAndStatus(userId, status, method string) (*model.RequestPickup, error)
FindRequestPickupByStatus(userId, status, method string) (*model.RequestPickup, error)
GetRequestPickupItems(requestPickupId string) ([]model.RequestPickupItem, error)
GetAutomaticRequestPickupsForCollector() ([]model.RequestPickup, error)
GetManualReqMethodforCollect(collector_id string) ([]model.RequestPickup, error)
// SelectCollectorInRequest(userId string, collectorId string) error
UpdateRequestPickup(id string, request *model.RequestPickup) error
DeleteRequestPickup(id string) error
}
type requestPickupRepository struct {
DB *gorm.DB
}
func NewRequestPickupRepository(db *gorm.DB) RequestPickupRepository {
return &requestPickupRepository{DB: db}
}
func (r *requestPickupRepository) CreateRequestPickup(request *model.RequestPickup) error {
if err := r.DB.Create(request).Error; err != nil {
return fmt.Errorf("failed to create request pickup: %v", err)
}
for _, item := range request.RequestItems {
item.RequestPickupId = request.ID
if err := r.DB.Create(&item).Error; err != nil {
return fmt.Errorf("failed to create request pickup item: %v", err)
}
}
return nil
}
func (r *requestPickupRepository) CreateRequestPickupItem(item *model.RequestPickupItem) error {
if err := r.DB.Create(item).Error; err != nil {
return fmt.Errorf("failed to create request pickup item: %v", err)
}
return nil
}
func (r *requestPickupRepository) FindRequestPickupByID(id string) (*model.RequestPickup, error) {
var request model.RequestPickup
err := r.DB.Preload("RequestItems").First(&request, "id = ?", id).Error
if err != nil {
return nil, fmt.Errorf("request pickup with ID %s not found: %v", id, err)
}
return &request, nil
}
func (r *requestPickupRepository) FindAllRequestPickups(userId string) ([]model.RequestPickup, error) {
var requests []model.RequestPickup
err := r.DB.Preload("RequestItems").Where("user_id = ?", userId).Find(&requests).Error
if err != nil {
return nil, fmt.Errorf("failed to fetch all request pickups: %v", err)
}
return requests, nil
}
func (r *requestPickupRepository) FindAllAutomaticMethodRequest(requestMethod, statuspickup string) ([]model.RequestPickup, error) {
var requests []model.RequestPickup
err := r.DB.Preload("RequestItems").Where("request_method = ? AND status_pickup = ?", requestMethod, statuspickup).Find(&requests).Error
if err != nil {
return nil, fmt.Errorf("error fetching request pickups with request_method %s: %v", requestMethod, err)
}
return requests, nil
}
func (r *requestPickupRepository) FindRequestPickupByAddressAndStatus(userId, status, method string) (*model.RequestPickup, error) {
var request model.RequestPickup
err := r.DB.Preload("Address").Where("user_id = ? AND status_pickup = ? AND request_method =?", userId, status, method).First(&request).Error
if err != nil {
if err == gorm.ErrRecordNotFound {
return nil, nil
}
return nil, fmt.Errorf("failed to check existing request pickup: %v", err)
}
return &request, nil
}
func (r *requestPickupRepository) FindRequestPickupByStatus(userId, status, method string) (*model.RequestPickup, error) {
var request model.RequestPickup
err := r.DB.Where("user_id = ? AND status_pickup = ? AND request_method =?", userId, status, method).First(&request).Error
if err != nil {
if err == gorm.ErrRecordNotFound {
return nil, nil
}
return nil, fmt.Errorf("failed to check existing request pickup: %v", err)
}
return &request, nil
}
func (r *requestPickupRepository) UpdateRequestPickup(id string, request *model.RequestPickup) error {
err := r.DB.Model(&model.RequestPickup{}).Where("id = ?", id).Updates(request).Error
if err != nil {
return fmt.Errorf("failed to update request pickup: %v", err)
}
return nil
}
// func (r *requestPickupRepository) SelectCollectorInRequest(userId string, collectorId string) error {
// var request model.RequestPickup
// err := r.DB.Model(&model.RequestPickup{}).
// Where("user_id = ? AND status_pickup = ? AND request_method = ? AND collector_id IS NULL", userId, "waiting_collector", "manual").
// First(&request).Error
// if err != nil {
// if err == gorm.ErrRecordNotFound {
// return fmt.Errorf("no matching request pickup found for user %s", userId)
// }
// return fmt.Errorf("failed to find request pickup: %v", err)
// }
// err = r.DB.Model(&model.RequestPickup{}).
// Where("id = ?", request.ID).
// Update("collector_id", collectorId).
// Error
// if err != nil {
// return fmt.Errorf("failed to update collector_id: %v", err)
// }
// return nil
// }
func (r *requestPickupRepository) DeleteRequestPickup(id string) error {
if err := r.DB.Where("request_pickup_id = ?", id).Delete(&model.RequestPickupItem{}).Error; err != nil {
return fmt.Errorf("failed to delete request pickup items: %v", err)
}
err := r.DB.Delete(&model.RequestPickup{}, "id = ?", id).Error
if err != nil {
return fmt.Errorf("failed to delete request pickup: %v", err)
}
return nil
}
func (r *requestPickupRepository) GetAutomaticRequestPickupsForCollector() ([]model.RequestPickup, error) {
var requests []model.RequestPickup
err := r.DB.Preload("Address").
Where("request_method = ? AND status_pickup = ? AND collector_id = ?", "otomatis", "waiting_collector", nil).
Find(&requests).Error
if err != nil {
return nil, fmt.Errorf("error fetching pickup requests: %v", err)
}
return requests, nil
}
func (r *requestPickupRepository) GetManualReqMethodforCollect(collector_id string) ([]model.RequestPickup, error) {
var requests []model.RequestPickup
err := r.DB.Where("request_method = ? AND status_pickup = ? AND collector_id = ?", "otomatis", "waiting_collector", collector_id).
Find(&requests).Error
if err != nil {
return nil, fmt.Errorf("error fetching pickup requests: %v", err)
}
return requests, nil
}
func (r *requestPickupRepository) GetRequestPickupItems(requestPickupId string) ([]model.RequestPickupItem, error) {
var items []model.RequestPickupItem
err := r.DB.Preload("TrashCategory").Where("request_pickup_id = ?", requestPickupId).Find(&items).Error
if err != nil {
return nil, fmt.Errorf("error fetching request pickup items: %v", err)
}
return items, nil
}