deleted bookings management
Some checks failed
Build and Push Docker Image / build_and_push (push) Has been cancelled
Some checks failed
Build and Push Docker Image / build_and_push (push) Has been cancelled
This commit is contained in:
@@ -1,6 +1,8 @@
|
||||
package handlers
|
||||
|
||||
import (
|
||||
"time"
|
||||
|
||||
"git.coopgo.io/coopgo-platform/fleets/storage"
|
||||
"github.com/google/uuid"
|
||||
)
|
||||
@@ -24,23 +26,15 @@ func (h FleetsHandler) GetBooking(id string) (booking *storage.Booking, err erro
|
||||
return nil, err
|
||||
}
|
||||
|
||||
// if booking.Deleted {
|
||||
// return nil, errors.New("booking was deleted")
|
||||
// }
|
||||
|
||||
vehicle, err := h.storage.GetVehicle(booking.Vehicleid)
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
if err != nil {
|
||||
return nil, err
|
||||
}
|
||||
booking.Vehicle = *vehicle
|
||||
return
|
||||
}
|
||||
|
||||
func (h FleetsHandler) UpdateBooking(booking storage.Booking) (*storage.Booking, error) {
|
||||
|
||||
// Store the account
|
||||
if err := h.storage.UpdateBooking(booking); err != nil {
|
||||
return nil, err
|
||||
@@ -49,8 +43,33 @@ func (h FleetsHandler) UpdateBooking(booking storage.Booking) (*storage.Booking,
|
||||
return &booking, nil
|
||||
}
|
||||
|
||||
func (h FleetsHandler) DeleteBooking(id string) error {
|
||||
return h.storage.DeleteBooking(id)
|
||||
func (h FleetsHandler) DeleteBooking(id string, deletionMetadata map[string]any) error {
|
||||
// Get the existing booking
|
||||
booking, err := h.storage.GetBooking(id)
|
||||
if err != nil {
|
||||
return err
|
||||
}
|
||||
|
||||
// Mark as deleted instead of hard delete
|
||||
booking.Deleted = true
|
||||
|
||||
// Add deletion metadata to data
|
||||
if booking.Data == nil {
|
||||
booking.Data = make(map[string]any)
|
||||
}
|
||||
|
||||
// Add deletion timestamp
|
||||
booking.Data["deleted_at"] = time.Now().Format(time.RFC3339)
|
||||
|
||||
// Merge provided deletion metadata
|
||||
if deletionMetadata != nil {
|
||||
for key, value := range deletionMetadata {
|
||||
booking.Data[key] = value
|
||||
}
|
||||
}
|
||||
|
||||
// Update the booking instead of deleting
|
||||
return h.storage.UpdateBooking(*booking)
|
||||
}
|
||||
|
||||
func (h FleetsHandler) GetBookings() ([]storage.Booking, error) {
|
||||
|
||||
Reference in New Issue
Block a user